Vue中使用七牛云上传报错o.upload.addEventListener is not a function以及其他报错问题

1.运行提示o.upload.addEventListener is not a function
解决方案:(此方法不是根本解决办法,问题3的解决办法是最终解决方案)
找到node_modules/mockjs/dist/mock.js 第8308行
找到node_modules/mockjs/src/xhr/xhr.js 第216行(确保在生产模式下打包出来的代码正常使用。)
添加代码: MockXMLHttpRequest.prototype.upload = xhr.upload;

2.上传文件链接返回提示 no such bucket
这是后端给你的token有问题,让后端去设置一下正确的bucket再生成token给你

3…上传文件过程报错cannot read property ‘total’ of null(文件能传成功,无法获取执行回调)
这是由于vue-cli中的mockjs模块全局使用了MockXMLHttpRequest,而七牛sdk本身使用的是XMLHttpRequest按照标准来的,但是vue-cli中的mockjs模块硬是把XMLHttpRequest自己封装一下导致冲突,会导致对象属性访问不到,删除mockjs模块即可。
解决方法:npm uninstall mockjs 删除该模块依赖

作者:追寻1979
链接:https://www.jianshu.com/p/b28fbab95b5a
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值