vue项目使用手机浏览器访问时报错:Uncaught TypeError: Object.assign is not a function

原因:

Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign)都不会转码。举例来说,ES6在Array对象上新增了Array.from方法。Babel就不会转码这个方法。如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个垫片。

Babel默认不转码的API非常多,详细清单可以查看babel-plugin-transform-runtime模块的definitions.js文件。

 

解决方案:

首先,使用 node 安装 *babel-polyfill 命令*
npm install --save-dev -polyfill

解决方案1:在 webpack.config.js 文件中,entry 入口处修改,加入即可
"babel-polyfill":"babel-polyfill",//用来解决的兼容性
例如:
entry: {
    "babel-polyfill":"babel-polyfill",//用来解决兼容性
    app: path.resolve(__dirname, config.entry.module + "/app.js"),
    vendor: config.entry.vendor
},

解决方案2:不修改webpack的情况下,在你的主入口文件头部加入,例如:app.js中加入即可
import 'babel-polyfill' 或者 require('babel-polyfill');
例如:
import 'babel-polyfill'
import Vue from 'vue';
Vue.config.debug = true;

如果嫌引入babel-polyfill太大,人家还提供了单项的polyfill,比如说我就只用到Object.assign和promise的,详情看这里

解决方案3:也就是使用cdn的资源,以js的文件加入到html页面:例如:
<script src="https://cdn.bootcss.com/babel-polyfill/6.23.0/polyfill.min.js"></script>

 

ES6 Object.assign介绍参见:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/assign#Browser_compatibilit

 

参考文件:

es6 Object.assign方法:http://www.cnblogs.com/chaoran/p/6410018.html

babel的polyfill和runtime的区别:https://segmentfault.com/q/1010000005596587/a-1020000005596816

shim和polyfill有什么区别:https://zhidao.baidu.com/question/1767408997770762580.html

怎样设置babel-polyfill:https://segmentfault.com/a/1190000008706628

 

发布了112 篇原创文章 · 获赞 604 · 访问量 152万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览