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) //必須經過回調函數返回,不然沒法及時拿到該值 } }