当前位置: 首页 > news >正文

长沙手机网站建设哪些内容/百度seo优

长沙手机网站建设哪些内容,百度seo优,自己的网站统计输入词,阳春网站建设最近项目用到了vuethink,里面集成了element-ui,之前一直用的是bootstrap框架,对js也是一知半解,然后也用过vue.js,但也是学的不通透的,然后就各种入坑。 下面就分析一下我使用element-ui遇到的问题以及解决…

最近项目用到了vuethink,里面集成了element-ui,之前一直用的是bootstrap框架,对js也是一知半解,然后也用过vue.js,但也是学的不通透的,然后就各种入坑。

下面就分析一下我使用element-ui遇到的问题以及解决方法吧,如有不足请指正。

首先在element-ui的官网里有对upload组件的简单的介绍

复制代码
1  <el-upload
2    class="upload-demo"
3    action="https://jsonplaceholder.typicode.com/posts/"
4    :on-preview="handlePreview"
5    :on-remove="handleRemove"
6    :file-list="fileList">
7    <el-button size="small" type="primary">点击上传</el-button>
8    <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div>
9 </el-upload>
复制代码

 

其实upload就是对input type="file"做了几层样式封装

一 action url

我第一个不理解的就是action中的url,我后台使用的是PHP语言,根据我之后的理解,这个url其实就是你PHP使用的上传的函数,就和form中的action一样,不一样的是我找了好久也没发现是否能修改默认的post传递方式

二 文件接收的同时,传递其他参数

方案一 url传参

对PHP提供的url进行传参,这是最直接能想到的方式,但是因为action中是post方式的,而PHP后台我使用的restful方式的url,post方式无法实现传参,我试了好几种都没能成功,也不知道要如何改成get方式

第一种方案只能放弃

方案二 不使用action

 放弃action,在找了好多资料后发现可以不使用action,而是用before-upload属性,这是一个function类型的属性,默认参数是当前文件,只要能传递这个文件也能实现效果

要传递这个方法就需要new一个formdata对象,然后对这个对象追加key和value,类似于postman测试时那样

具体网上有人给的例子,差不多如下

 

复制代码
   beforeUpload (file) {let fd = new FormData()fd.append('key', file, fileName)axios.post(url, fd. {//做一些操作})return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传},
复制代码

 

这个感觉可以一试,然后我理所当然的写了一下的方式

复制代码
 1    beforeUpload (file,id) {2       let fd = new FormData()3       fd.append('key', file, fileName)4       axios.post(url, fd. {5         data:{6          id:id7         }8       })9       return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
10     },
复制代码

 

然后我发现无论怎么样我都只能传过去id,在PHP代码中dump(_FLIES)永远是NULL,这就非常火大了,查了好久没有解决方法,之后发现我用的Content-Type应该是multipart/form-data,而f12中调试页面是application/json; charset=utf-8,我就觉得是不是这个的问题,于是在代码中又加了headers

复制代码
    beforeUpload (file,id) {let fd = new FormData()fd.append('key', file, fileName)axios.post(url, fd. {data:{id:id},headers: {'Content-Type': 'multipart/form-data'}})return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传},
复制代码

 

这次报的错是axios Missing boundary in multipart/form-data,没有边界,很头疼无语

后来发现Content-Type是自动识别然后加边界的,也有人说要把Content-Type定义为undefined,还是不行,只是自动识别Content-Type,

再后来发现原来传递formdata和data不能一起传递,要传递formdata就不能有data,所以要改为

复制代码
1 beforeUpload (file,id) {
2     let fd = new FormData()
3     fd.append('file', file)
4     fd.append('id',id)
5     axios.post(url, fd, {
6          
7     })
8     return false // false就是不自动上传,我后来试了发现都一样,都不会自动上传
9  },
复制代码

 

这样就可以了

以下是我的代码

复制代码
 1         <el-upload class="upload-demo"2             drag3             action="123"4             :before-upload="beforeUpload"5             multiple6             ref="newupload"7             :auto-upload="false"8             accept=".mp4,.flv,.mov"9             :on-change="newhandleChange"
10             :on-success="newhandlesuccess">
11             <i class="el-icon-upload"></i>
12             <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em>     </div>
13             <div class="el-upload__tip" slot="tip">请注意您只能上传.mp4 .flv .mov格式的视频文件</div>
14           </el-upload>
15           el-button type="primary" @click="newSubmitForm()" class="yes-btn">
16             确 定
17           </el-button>
18           <el-button @click="resetForm('newform')">
19             重 置
20           </el-button>
复制代码

 

复制代码
 1    beforeUpload (file) {2       console.log(file)3       let fd = new FormData()4       fd.append('file', file)5       fd.append('groupId', this.groupId)6       // console.log(fd)7       newVideo(fd).then(res => {8         console.log(res)9       })
10       return true
11     },
复制代码
1    newSubmitForm () {
2       this.$refs.newupload.submit()
3     },

 

复制代码
1 export function newVideo (data) {
2   return axios({
3     method: 'post',
4     url: 'http://localhost:8086/Platform1-back-end/public/admin/VideoBase/newVideo',
5     timeout: 20000,
6     data: data
7   })
8 }
复制代码

 

我是把axios集中放在一个文件,与vue文件分离了,其实都差不多

还有就是action中随便加一个东西会有404错误,但是不影响最终效果,介意的可以看看有什么方法去除

方案三 分多次传值

方案二成功了就没有试,不过也没有意义了不方便

http://www.cnblogs.com/liuruolin/p/7517470.html

http://www.lbrq.cn/news/836335.html

相关文章:

  • 自建服务器做网站/seo优化一般包括哪些内容()
  • 小程序diy制作平台/网站seo快速优化技巧
  • 惠州专业做网站公司/重庆优化seo
  • 武汉做网站seo/免费发布广告
  • 咸宁网站开发/seo黑帽培训骗局
  • 网站首页备案号链接/谷歌外贸平台推广需要多少钱
  • 河南疫情防控最新消息/太原百度快照优化排名
  • 2013年以前pc网站建设/网络推广优化seo
  • 怎么把wordpress/衡水seo优化
  • 湖南 政府网站信息内容建设/百度推广优化师
  • 网站用什么做备份/百度推广获客
  • dedecms 5.7 通用企业网站模板/企业seo案例
  • 建设银行网站怎样查询贷款信息查询/网络推广项目代理
  • 作品集怎么做网页/seo建站公司推荐
  • 眼睛网站开发/国内搜索引擎排名2022
  • 婚纱摄影的网站怎么做/网络广告是什么
  • 中国建设银行网站-个人客户/如何制作网页
  • 校友会网站建设/seo管理
  • 缤纷网站免费做服装/seo外链怎么做能看到效果
  • 石家庄网站公司/小辉seo
  • 软件开发公司怎么找客户/seo优化的网站
  • b2b网站建设报价/提高工作效率英语
  • 网站开发保密协议模板/纯注册app拉新平台
  • 赣州建网站/seo诊断工具有哪些
  • 深圳注册公司育君财税/高级seo
  • 上线了做网站怎么样/搜索引擎排名优化方案
  • 把网站打包微信小程序/外链信息
  • 网站建设报价明细模板/软件培训班
  • 网站上面的内容里面放照片怎么做的/优化seo报价
  • 如何做网站url优化/品牌运营方案
  • redis中间件
  • x3CTF-2025-web-复现
  • 医院各类不良事件上报,PHP+vscode+vue2+element+laravel8+mysql5.7不良事件管理系统源代码,成品源码,不良事件管理系统
  • 阿里云-通义灵码:隐私保护机制—为数据安全筑起铜墙铁壁
  • cdh6.3.2的hive使用apache paimon格式只能创建不能写报错的问题
  • 深度学习前置知识