您的位置:首页 > 移动开发 > Objective-C

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

2017-06-02 19:32 1116 查看
原因:

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: