Jeeplus-vue 实现文件的上传功能

 更新时间:2022年09月10日 09:43:14   作者:Echo丶洛尘  
这篇文章主要介绍了Jeeplus-vue 实现文件的上传,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

前端

一、uploadList.vue

① 首先在页面中添加一个放置图片的位置,来展示图片

	<el-table-column
	  prop="upload"
	  label="高校证明材料">
	  <template slot-scope="scope" v-if="scope.row.upload">
	    <el-image
	      style="height: 30%;width:30%;margin-left:22%;"
	      :src="src"
	      v-for="(src, index) in scope.row.upload.split(',')" :key="index"
	      :preview-src-list="scope.row.upload.split(',')">
	    </el-image>
	  </template>
	</el-table-column>

② 在data中添加相关属性

data () {
	return{
		searchForm:{
			upload: ''
		},
		loading: false,
        src: '' // 上传图片
}

二、testForm.vue

① 在表单中添加下列代码

<el-col :span="12">
		    <el-form-item label="上传图片" prop="upload">
		      <el-upload
		        list-type="picture-card"
		        :action="`${this.$http.BASE_URL}/sys/file/webupload/upload?uploadPath=/upload`"
		        :headers="{token: $cookie.get('token')}"
				:before-upload="beforeUpload"
		        :on-preview="(file, fileList) => {
		            $alert(`<img style='width:100%' src=' ${(file.response && file.response.url) || file.url}'/>`,  {
		              dangerouslyUseHTMLString: true,
		              showConfirmButton: false,
		              closeOnClickModal: true,
		              customClass: 'showPic'
		            });
		        }"
		        :on-success="(response, file, fileList) => {
		           inputForm.collegeMaterials = fileList.map(item => (item.response && item.response.url) || item.url).join('|')
		        }"
		        :on-remove="(file, fileList) => {
		          $http.post(`/sys/file/webupload/deleteByUrl?url=${(file.response && file.response.url) || file.url}`).then(({data}) => {
		            $message.success(data.msg)
		          })
		          inputForm.collegeMaterials = fileList.map(item => item.url).join('|')
		        }"
		        :before-remove="(file, fileList) => {
		          return $confirm(`确定删除 ${file.name}?`)
		        }"
		        multiple
		        :limit="1"
		        :on-exceed="(files, fileList) =>{
		          $message.warning(`当前限制选择 1 个图片,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个图片`)
		        }"
		        :file-list="picArra">
		        <i class="el-icon-plus"></i>
		      </el-upload>
		      <el-dialog :visible.sync="dialogVisible">
		        <img width="100%" :src="dialogImageUrl" alt="">
		      </el-dialog>
		  </el-form-item>
		</el-col>

② 在data中添加相关属性

 data () {
      return {
        picArra: [],
        dialogImageUrl: '',
        dialogVisible: false,
        disabled: false,
        inputForm: {
        upload: '',
        }
      }
 }

③ 在method中替换原始的 this.$nextTick

        this.visible = true
        this.loading = false
        // 重置图片路径,否则会加载上一次添加的图片
        this.picArra = []
        this.$nextTick(() => {
          this.$refs.inputForm.resetFields()
          if (method === 'edit' || method === 'view') { // 修改或者查看
            this.loading = true
            this.$http({
            // upload为controller层的注解路径,替换一下即可
              url: `/upload/queryById?id=${this.inputForm.id}`,
              method: 'get'
            }).then(({data}) => {
              this.inputForm = this.recover(this.inputForm, data.college)
              this.inputForm.upload.split('|').forEach((item) => {
                if (item.trim().length > 0) {
                  this.picArra.push({name: decodeURIComponent(item.substring(item.lastIndexOf('/') + 1)), url: item})
                }
              })
              this.loading = false
            })
          }
        }),
                // 查看图片
      handlePictureCardPreview (file) {
        this.dialogImageUrl = file.url
        this.dialogVisible = true
      },
      continueDoSubmit () {
        this.$refs['inputForm'].validate((valid) => {
          if (valid) {
            this.$emit('addRow', this.oldInputForm, JSON.parse(JSON.stringify(this.inputForm)))
            this.$refs['inputForm'].resetFields()
          }
        })
      },
      // 判断上传图片的格式
      beforeUpload (file) {
        if (file) {
          const suffix = file.name.split('.')[1]
          const size = file.size / 1024 / 1024 < 2
          if (['png', 'jpeg', 'jpg'].indexOf(suffix) < 0) {
            this.$message.error('上传图片只支持 png、jpeg、jpg 格式!')
            this.$refs.upload.clearFiles()
            return false
          }
          if (!size) {
            this.$message.error('上传文件大小不能超过 2MB!')
            return false
          }
          return file
        }
      }

后端

后端只需要将相应的字段添加好即可,controller层不需要改动。

到此这篇关于Jeeplus-vue 实现文件的上传的文章就介绍到这了,更多相关vue文件上传内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何使用Vue3实现文章内容中多个"关键词"标记高亮显示

    如何使用Vue3实现文章内容中多个"关键词"标记高亮显示

    高亮显示是我们日常开发中经常会遇到的需求,下面这篇文章主要给大家介绍了关于如何使用Vue3实现文章内容中多个"关键词"标记高亮显示的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • Vue组件模板及组件互相引用代码实例

    Vue组件模板及组件互相引用代码实例

    这篇文章主要介绍了Vue组件模板及组件互相引用代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • vue-prop父组件向子组件进行传值的方法

    vue-prop父组件向子组件进行传值的方法

    下面小编就为大家分享一篇vue-prop父组件向子组件进行传值的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • vue 每次渲染完页面后div的滚动条保持在最底部的方法

    vue 每次渲染完页面后div的滚动条保持在最底部的方法

    下面小编就为大家分享一篇vue 每次渲染完页面后div的滚动条保持在最底部的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • Vue3项目中引入html页面的方法举例

    Vue3项目中引入html页面的方法举例

    这篇文章主要给大家介绍了关于Vue3项目中引入html页面的相关资料,Vue3是一个JavaScript框架,通常我们使用它来构建单页应用程序(SPA),如果你想在HTML页面中使用Vue3,可以参考这篇文章,需要的朋友可以参考下
    2023-09-09
  • 在Vue2中v-model和.sync区别解析

    在Vue2中v-model和.sync区别解析

    在vue2中提供了.sync修饰符,但是在vue3中不再支持.sync,取而代之的是v-model,本文给大家介绍在Vue2中v-model和.sync区别,感兴趣的朋友一起看看吧
    2023-10-10
  • vue2手机APP项目添加开屏广告或者闪屏广告

    vue2手机APP项目添加开屏广告或者闪屏广告

    这篇文章主要为大家详细介绍了vue2手机APP项目添加开屏广告或者闪屏广告的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Vue 打包体积优化方案小结

    Vue 打包体积优化方案小结

    这篇文章主要介绍了Vue 打包体积优化方案小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • element-ui中Table表格省市区合并单元格的方法实现

    element-ui中Table表格省市区合并单元格的方法实现

    这篇文章主要介绍了element-ui中Table表格省市区合并单元格的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • vue+iview Table表格多选切换分页保持勾选状态

    vue+iview Table表格多选切换分页保持勾选状态

    这篇文章主要为大家详细介绍了vue+iview Table表格多选切换分页保持勾选状态,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07

最新评论