package.json 已经有依赖"babel-polyfill": "^6.23.0"了,使用 babel-cli 命令行 babel xx -d xx 来转换,但 Array.of 没有被转换成 ES5,不知道什么地方有问题
转换前
require('babel-polyfill');
(x => x * 2)(1);
var b = Array.of(1,2,4);
转换后
'use strict';
require('babel-polyfill');
(function (x) {
return x * 2;
})(1);
var b = Array.of(1, 2, 4);
1
yyfearth 2017-06-22 12:19:52 +08:00 via iPhone
既 polyfill 了,为什么还要转换。polyfill 意思就是某个功能不支持,就把它补上。
所以 里面应该已经实现了 Array.of 了。 当然,如果运行的时候抱错了,那就说明没用上。 |
3
larvata 2017-06-22 12:31:15 +08:00
你这个姿势就是正确的
babel 只负责转换语法 babel-polyfill 是负责补上方法的实现 |
4
larvata 2017-06-22 12:35:36 +08:00
给浏览器用 你需要 webpack 之类的东西帮你做 require
|
5
zhanziyang 2017-06-22 12:36:38 +08:00
babel-polyfill 应该是改进了 Array 的 prototype,这样你就可以正常使用 Array.of 了,代码不用转化
|
6
mooncakejs 2017-06-22 12:40:25 +08:00
babel-polyfill 打包 manifest 的时候会有问题(double),目前我的解决方式是不打包进去。
script 代码前加一个 判断,如果不支持,document.write('<script src="polyfill"></script>') |
7
peneazy OP @larvata 哦,需要打包工具。想看看 ES5 是怎么实现的 Array.of 等方法的,看样子没有简单的办法看到了。。
|
8
doubleflower 2017-06-22 13:05:37 +08:00
@peneazy 看不懂 LZ 是什么个意思? Array.of 不是 API 调用吗,又不是 ES6 语法,怎么需要转到 ES5 ?已经是 ES5 了。
|
9
peneazy OP @doubleflower ES5 没有这个 API,我想让文件里 API 使用前单独加上
```javascript if (!Array.of) { Array.of = function() { return Array.prototype.slice.call(arguments); }; } ``` |
10
otakustay 2017-06-22 13:23:20 +08:00
babel-polyfill 里就是很多你说的单独加上的这种方法,你 require 过了这些方法就在了
|
11
otakustay 2017-06-22 13:23:51 +08:00
如果你要的是“用到 of 就加 of ”这种定制的 polyfill 的话,因为 js 的动态性几乎不可能做到,请不要太过纠结
|
12
arzusyume 2017-06-22 13:28:01 +08:00
楼主可能是混淆了 polyfill 和 transpiler 的定义
|
14
doubleflower 2017-06-22 14:27:29 +08:00
@peneazy 什么意思?把 Array.of 的实现内联到调用处?还是在你的源代码的每个文件上部都放上一个实现? babel 不是这么玩的啊。
还是你要看 array.of 实现代码?直接去看 core-js 源码不就得了。 |
15
whosesmile 2017-06-22 15:24:09 +08:00
楼主查下 babel-runtime,它和 babel-polyfill 不一样的地方是:polyfill 是一个全量引用,runtime 会根据你的使用,将 ES6 的一些新的 API 编译成 ES5 的。
估计是你所期望看到的了 |
16
peneazy OP @whosesmile 谢啦,研究一下
|
17
jruit 2020-05-27 08:12:25 +08:00
|