金鹏信息后台管理组件—文件上传组件

1. 简介

利用element UI开发的vue单文件,多文件上传组件。

2. 基础环境

(vue 2.6.0 +) (nodejs 6.0+)

3. 使用前准备(nrm for vue)

3.1. 简介

nrm 是一个 NPM 源管理器,允许你快速地在如下 NPM 源间切换.

3.2. 安装

    npm install -g nrm

3.3. 使用

3.3.1. 列出可选的NPM源

    ; nrm ls                                                                                                                                    
    * npm ---- https://registry.npmjs.org/
      cnpm --- http://r.cnpmjs.org/
      taobao - http://registry.npm.taobao.org/
      eu ----- http://registry.npmjs.eu/
      au ----- http://registry.npmjs.org.au/
      sl ----- http://npm.strongloop.com/
      nj ----- https://registry.nodejitsu.com/

3.3.2. 切换NPM源

    ; nrm use taobao                                                                                                                             
     Registry has been set to: http://registry.npm.taobao.org/

3.3.3. 增加源 (你可以增加定制的源,特别适用于添加企业内部的私有源)

nrm add jpxx http://xxx.xx.xx.xxx

3.3.4. 删除源

nrm del jpxx

4. 如何使用

4.1. 项目依赖

//npm install file -S
//在main.js中
import file from 'file'
Vue.use(file)

4.2. 引用

<file v-model="files" @change='filesChange'></file>

5. 事件

事件名 说明 参数
change 选中值发生变化时触发 目前选择的值

6. 实现细节

6.1. 单文件上传

  • 这里是的上传input输入框,我用绝对定位将其放在后面的input 显示框的上面,后面的正常在文档流中,显示正常,又将绝对定位的上传框opacity设为0,这下只能显示后面的输入框,但点击输入框的时候上传框在因为绝对定位在其上面,所以会点击到上传框从而达到上传文件的效果

  • 每次上传图片会触发上传框的change事件,我们获取到输入框的文件,然后获取其name,将其name赋值给filename,上面的输入框绑定了filename的值,所以会显示上传图片的文件名, 这样每次上传文件,文件名都会是新上传图片的名称。

  • 有上传文件的接口一般是form表单的参数格式,等到提交表单的时候可以用 FormData对象去append各个参数就可以了。

6.2. 多文件上传

  • 多文件和上面文件思路差不多,但是有一点是不同的,既然多文件,可以连续删掉多个,一次添加多个,或者多次添加一个,这就不能讲文件名在输入框里显示了。

  • 我们可以将上传框和单文件上传一样,设置绝对定位在上传按钮或者输入框的上面,上传框设置multiple属性,可一次上传多个。

  • 我们将文件名和文件调价到不通数组,文件名数组fileList在模板里用v-for遍历,每次上传都可以看到下面新增的文件名,参考多文件保单图,如有需要删除,我们将要将其图片在文件名数组中的index值传入删减函数,删除对应文件名,然后将其在文件数组中的同index文件删除,这样就可以实现不断加不断删的功能。不过,每次删除之前都要讲输入框的value值清空,这样删除之后还可以上传之前删除的文件。最后还是用FormData对象添加参数。

源码地址:http://sources.jpsycn.com/dev-plat/h5/com/file.git

Copyright © jpsycn.com 2018 all right reserved,powered by Gitbook该文件修订时间: 2019-09-10 14:26:09

results matching ""

    No results matching ""