V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
peneazy
V2EX  ›  JavaScript

babel-polyfill 正确使用姿势是啥

  •  
  •   peneazy · 2017-06-22 11:38:18 +08:00 · 3387 次点击
    这是一个创建于 2497 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

    估计是你所期望看到的了
    peneazy
        16
    peneazy  
    OP
       2017-06-22 16:29:10 +08:00
    @whosesmile 谢啦,研究一下
    jruit
        17
    jruit  
       2020-05-27 08:12:25 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3536 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 11:13 · PVG 19:13 · LAX 04:13 · JFK 07:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.