js方法
<script src="//unpkg.com/element-ui@1.4.1/lib/index.js"></script>
<div id="app" ref = 'find'>
<el-upload action="https://jsonplaceholder.typicode.com/posts/" list-type="picture-card" :on-preview="handlePictureCardPreview" :on-remove="handleRemove" :on-change = "handleChange">
<i class="el-icon-plus"></i>
</el-upload>
<el-dialog v-model="dialogVisible" size="tiny">
data:image/s3,"s3://crabby-images/64672/64672f8a53d7ee137f6c15110b1ae0552baf50b0" alt=""
</el-dialog>
</div>
var Main = {
data() {
return {
dialogImageUrl: '',
dialogVisible: false
};
},
methods: {
handleChange () {
this.$refs.find.querySelector(".el-upload--picture-card").style.background = 'red'
},
handleRemove(file, fileList) {
this.$refs.find.querySelector(".el-upload--picture-card").style.background = 'green'
console.log(file, fileList);
},
handlePictureCardPreview(file) {
this.dialogImageUrl = file.url;
this.dialogVisible = true;
}
}
}
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')
data:image/s3,"s3://crabby-images/a5e88/a5e88549541d238a716dc9590129ccad70357784" alt=""
另一种思维:
也可以在外层包个class,然后设置class宽度
超出部分隐藏overflow:hidden
data:image/s3,"s3://crabby-images/6c336/6c3367f2fb29cf3752d078a09d58e8ac2ceeef06" alt=""
data:image/s3,"s3://crabby-images/faea1/faea1d696872c4b7a4347cea10189f5d68408db9" alt=""
这里其实应给el -form-item单独设立class也可实现这个效果
:on-change 可以改为 :on-sucess 当上传成功后再进行操作
网友评论