上傳base64圖片並壓縮

elementUI+reactreact

佈局canvas

         <Dialog
                    title="充值"
                    visible={ dialogVisible }
                    onCancel={ () => this.setState({ dialogVisible: false }) }
                >
                    <Dialog.Body>
                        <Form labelWidth="120" ref={ e => {this.form=e} } model={ form } rules={ rules }>
                            <Form.Item label="支付憑證" prop="voucher">
                                <div className="my-upload">
                                <input className="upload-input" type="file" id="input" name="file1" onChange={ this.inputfile } />
                                { voucher ? <img src={ voucher } className="avatar" alt="" /> : <i className="el-icon-plus avatar-uploader-icon" /> }
                                </div>
                            </Form.Item>
                        </Form>
                    </Dialog.Body>
                    <Dialog.Footer className="dialog-footer">
                        <Button onClick={ () => this.setState({ dialogVisible: false }) }>{'取 消'}</Button>
                        <Button type="primary" onClick={ this.saveContent } loading={ btnLoading }>{'確 定'}</Button>
                    </Dialog.Footer>
                </Dialog>

完整方法:函數

  beforeAvatarUpload(file) {
        const isJPG = file.type === 'image/jpeg'
        const isLt2M = file.size / 1024 / 1024 < 2
        if (!isJPG) {
            Message('上傳頭像圖片只能是 JPG 格式!')
        }
        if (!isLt2M) {
            Message('上傳頭像圖片大小不能超過 2MB!')
        }
        return isJPG && isLt2M
    }
  // input onchange上傳方法 inputfile
=()=> { const file1 = document.querySelector('#input').files[0] // const flag = this.beforeAvatarUpload(file1) // if(!flag){ // return false // } console.log(file1) const that=this if(file1){ var reader = new FileReader() // 圖片文件轉換爲base64 reader.readAsDataURL(file1) reader.onload = function(){ // 顯示圖片 // document.getElementById('file1_img').src = this.result // that.setState({ // voucher:this.result // }) that.dealImage(this.result, 800, that.printing) } } }
  //回調方法 printing
= base64 => { // console.log('壓縮後', base64.length / 1024) this.setState({ voucher: base64 }) } //壓縮方法 dealImage = (base64, w, callback) => { var newImage = new Image() //壓縮係數0-1之間 var quality = 0.6 newImage.src = base64 newImage.setAttribute('crossOrigin', 'Anonymous') //url爲外域時須要 var imgWidth, imgHeight newImage.onload = function () { imgWidth = this.width imgHeight = this.height var canvas = document.createElement('canvas') var ctx = canvas.getContext('2d') if (Math.max(imgWidth, imgHeight) > w) { if (imgWidth > imgHeight) { canvas.width = w canvas.height = w * imgHeight / imgWidth } else { canvas.height = w canvas.width = w * imgWidth / imgHeight } } else { canvas.width = imgWidth canvas.height = imgHeight quality = 0.6 } ctx.clearRect(0, 0, canvas.width, canvas.height) ctx.drawImage(this, 0, 0, canvas.width, canvas.height) var ba = canvas.toDataURL('image/jpeg', quality) //壓縮語句 // 如想確保圖片壓縮到本身想要的尺寸,如要求在50-150kb之間,請加如下語句,quality初始值根據狀況自定 // while (base64.length / 1024 > 150) { // quality -= 0.01; // base64 = canvas.toDataURL("image/jpeg", quality); // } // 防止最後一次壓縮低於最低尺寸,只要quality遞減合理,無需考慮 // while (base64.length / 1024 < 50) { // quality += 0.001; // base64 = canvas.toDataURL("image/jpeg", quality); // } callback(ba) //必須經過回調函數返回,不然沒法及時拿到該值 } }
相關文章
相關標籤/搜索