Skip to content

Instantly share code, notes, and snippets.

@ykhirao
Last active January 16, 2020 04:36
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save ykhirao/1d36aeca9abb02709cc9dd3d676040ef to your computer and use it in GitHub Desktop.
Save ykhirao/1d36aeca9abb02709cc9dd3d676040ef to your computer and use it in GitHub Desktop.
JSによる画像圧縮サンプル
<template>
<div class="upload">
<h1>Upload page</h1>
<div class="image-container">
<div class="image-text">
<label for="file">
<div>
Add your Images!
<br />Click me!
</div>
<input
type="file"
id="file"
multiple
accept="image/*"
style="display:none;"
@change="handleFiles"
/>
</label>
</div>
<!-- <img src="@/assets/sample.jpeg" /> -->
<!-- <img src="@/assets/sample2.jpeg" /> -->
<img v-bind:src="image" v-for="image in images" v-bind:key="image" alt />
<div v-if="this.images.length" class="image-text" @click="hundleUploadImages">
<span>Save all files!</span>
</div>
</div>
</div>
</template>
<script lang="ts">
import { Component, Prop, Vue } from 'vue-property-decorator'
import Compressor from 'compressorjs'
import ImageContainer from '@/components/ImageContainer.vue'
import * as firebase from 'firebase/app'
import 'firebase/storage'
@Component({
components: { ImageContainer },
directives: {},
filters: {},
mixins: []
})
export default class Update extends Vue {
images: string[] = [] // [""]
mounted() {
this.images.push(
``
)
}
hundleUploadImages(e: Event) {
// this.$emit('emitting', this.images)
var storageRef = firebase.storage().ref()
// var mountainImagesRef = storageRef.child('images/mountains.jpg')
this.images.forEach(image => {
console.log(image)
var mountainsRef = storageRef.child(
`${Math.random()
.toString(32)
.substring(2)}.jpg`
)
mountainsRef.putString(image, 'data_url').then(function(snapshot) {
console.log('Uploaded a blob or file!')
})
})
}
handleFiles(e: Event) {
const images = this.images
const files: FileList | null = (<HTMLInputElement>e.target).files
if (files === null) return
;[...files].forEach((file: File) => {
const payload: Compressor.Options = {
quality: 0.8,
maxWidth: 100,
maxHeight: 100,
mimeType: 'image/jpeg',
success(blob: Blob): void {
var reader = new FileReader()
reader.onloadend = () => {
const result = <string | ArrayBuffer | null>reader.result
if (result instanceof ArrayBuffer || result === null) return
images.push(result)
}
reader.readAsDataURL(blob)
},
error(err: Error): void {
console.log(err.message)
}
}
new Compressor(file, payload)
})
}
}
</script>
<style scoped lang="stylus">
.upload {
display: flex;
min-height: calc(100vh - 120px);
padding: 0;
margin: 0;
align-items: center;
justify-content: center;
flex-direction: column;
h1 {
font-size: 2em;
}
}
.image-container {
width: 100%;
max-width: 960px;
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
flex-wrap: wrap;
background-color: #eee;
padding: 20px 30px;
border-radius: 6px;
img {
height: 180px;
width: 240px;
object-fit: cover;
border-radius: 1%;
margin: 5px;
}
.image-text {
height: 180px;
width: 240px;
background-color: white;
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
font-size: 1.5em;
margin: 5px;
label {
cursor: pointer;
}
span {
cursor: pointer;
}
}
}
</style>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment