babel-polyfill 正确使用姿势是啥

2017-06-22 11:38:18 +08:00
 peneazy

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);
3405 次点击
所在节点    JavaScript
17 条回复
yyfearth
2017-06-22 12:19:52 +08:00
既 polyfill 了,为什么还要转换。polyfill 意思就是某个功能不支持,就把它补上。
所以 里面应该已经实现了 Array.of 了。
当然,如果运行的时候抱错了,那就说明没用上。
peneazy
2017-06-22 12:28:16 +08:00
@yyfearth 我是想把 js 文件转成 ES5 的,给浏览器用
larvata
2017-06-22 12:31:15 +08:00
你这个姿势就是正确的

babel 只负责转换语法 babel-polyfill 是负责补上方法的实现
larvata
2017-06-22 12:35:36 +08:00
给浏览器用 你需要 webpack 之类的东西帮你做 require
zhanziyang
2017-06-22 12:36:38 +08:00
babel-polyfill 应该是改进了 Array 的 prototype,这样你就可以正常使用 Array.of 了,代码不用转化
mooncakejs
2017-06-22 12:40:25 +08:00
babel-polyfill 打包 manifest 的时候会有问题(double),目前我的解决方式是不打包进去。
script 代码前加一个 判断,如果不支持,document.write('<script src="polyfill"></script>')
peneazy
2017-06-22 12:57:43 +08:00
@larvata 哦,需要打包工具。想看看 ES5 是怎么实现的 Array.of 等方法的,看样子没有简单的办法看到了。。
doubleflower
2017-06-22 13:05:37 +08:00
@peneazy 看不懂 LZ 是什么个意思? Array.of 不是 API 调用吗,又不是 ES6 语法,怎么需要转到 ES5 ?已经是 ES5 了。
peneazy
2017-06-22 13:21:58 +08:00
@doubleflower ES5 没有这个 API,我想让文件里 API 使用前单独加上
```javascript
if (!Array.of) {
Array.of = function() {
return Array.prototype.slice.call(arguments);
};
}
```
otakustay
2017-06-22 13:23:20 +08:00
babel-polyfill 里就是很多你说的单独加上的这种方法,你 require 过了这些方法就在了
otakustay
2017-06-22 13:23:51 +08:00
如果你要的是“用到 of 就加 of ”这种定制的 polyfill 的话,因为 js 的动态性几乎不可能做到,请不要太过纠结
arzusyume
2017-06-22 13:28:01 +08:00
楼主可能是混淆了 polyfill 和 transpiler 的定义
peneazy
2017-06-22 13:29:14 +08:00
@otakustay 感谢,暂时不纠结这个地方了
doubleflower
2017-06-22 14:27:29 +08:00
@peneazy 什么意思?把 Array.of 的实现内联到调用处?还是在你的源代码的每个文件上部都放上一个实现? babel 不是这么玩的啊。
还是你要看 array.of 实现代码?直接去看 core-js 源码不就得了。
whosesmile
2017-06-22 15:24:09 +08:00
楼主查下 babel-runtime,它和 babel-polyfill 不一样的地方是:polyfill 是一个全量引用,runtime 会根据你的使用,将 ES6 的一些新的 API 编译成 ES5 的。

估计是你所期望看到的了
peneazy
2017-06-22 16:29:10 +08:00
@whosesmile 谢啦,研究一下
jruit
2020-05-27 08:12:25 +08:00

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/370260

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX