@babel/preset-env, @babel/polyfill和@babel/plugin-transform-runtime

广告位招租
扫码页面底部二维码联系

在平时通过babel转code的时候,有本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net没有认真去研究一下这三个我们最常用的包呢【原创内容,转载请注明出处】【访问 www.tangshuang.net 获取更多精彩内容】?额……好像前面两个最常用,最后一个不常【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】用。有没有去思考过,为啥要有这些包的区分【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。?在什么情况下使用呢?这篇文章就讲解一下原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】

【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net【转载请注明来源】【原创不易,请尊重版权】

@babel/preset-env【关注微信公众号:wwwtangshuangnet】

本文版权归作者所有,未经授权不得转载。【转载请注明来源】【转载请注明来源】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。

这可以说是babel官方的得意之作,最早本文版权归作者所有,未经授权不得转载。【转载请注明来源】的时候没有这个包,有的是babel-pr未经授权,禁止复制转载。【原创不易,请尊重版权】eset-es2015这样的包,后来每次转载请注明出处:www.tangshuang.net原创内容,盗版必究。新标准发布之后,就要新加一个包。babe本文作者:唐霜,转载请注明出处。【转载请注明来源】l顺应民意,发布了babel-prese本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】t-env这个包,它一次性囊括了已发布的【原创不易,请尊重版权】未经授权,禁止复制转载。所有标准包。

【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】

首先我们需要明确一下,preset-en【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。v的首要作用,不是帮我们把ES6+代码转原创内容,盗版必究。【未经授权禁止转载】成ES5.它的首要作用是认读ES6+代码原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。。在使用preset-env之前,bab【原创不易,请尊重版权】转载请注明出处:www.tangshuang.netel是无法认识ES6+代码的,运行时会报【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。Token错误。在使用preset-en【未经授权禁止转载】【本文受版权保护】v之后,babel才能认识这些代码语法,【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。并将它们抽象出AST树。

著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net

其次的作用,才是帮我们转码代码。babe本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】l preset说白了,就是一大堆bab【原创不易,请尊重版权】转载请注明出处:www.tangshuang.netel plugin的集合。babel的一原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】切转码功能都是靠插件完成的。当然,插件要未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net发挥作用,离不开babel本身的AST抽【未经授权禁止转载】【原创不易,请尊重版权】象能力。也就是babel为插件提供了AS本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.netT能力,而插件利用该能力,创建/修改AS未经授权,禁止复制转载。原创内容,盗版必究。T。

【作者:唐霜】本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】

preset-env本身包含了一大堆pl著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。ugin,并通过配置来控制插件,从而控制原创内容,盗版必究。【未经授权禁止转载】转码效果。我们来看下它的几个我们需要了解本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】的常用选项(非常用的不介绍)。

转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net【未经授权禁止转载】

targets【关注微信公众号:wwwtangshuangnet】

本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。

转码之后,要兼容哪些环境。可以在这里控制【版权所有,侵权必究】转载请注明出处:www.tangshuang.net目标浏览器。随着版本控制的不同,最终生成著作权归作者所有,禁止商业用途转载。【本文受版权保护】的代码量也不一样,所以,不要一次性兼容到著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。最低版本,没必要。

【转载请注明来源】【版权所有】唐霜 www.tangshuang.net【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】

它有一个特殊选项 【关注微信公众号:wwwtangshuangnet】targets.esmodules ,如果这个选项为true,那么表示直接原创内容,盗版必究。本文作者:唐霜,转载请注明出处。转化为ES6模块规范,而不会转码到req【本文受版权保护】本文版权归作者所有,未经授权不得转载。uire。

未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。

modules【访问 www.tangshuang.net 获取更多精彩内容】

【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】【原创内容,转载请注明出处】

将当前模块加载类型转为哪个目标模块类型。原创内容,盗版必究。【作者:唐霜】默认为commonjs,设置为false【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】时,不会转码模块加载,import fr【版权所有,侵权必究】【转载请注明来源】om 语法不会转码,这样可以用来为web【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.netpack做tree shaking。

【原创内容,转载请注明出处】原创内容,盗版必究。【转载请注明来源】本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。

useBuiltIns本文作者:唐霜,转载请注明出处。

未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】【版权所有,侵权必究】【原创内容,转载请注明出处】

是否自动加载polyfill。它有三个值【作者:唐霜】【作者:唐霜】可选:false(默认), entry,著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】 usage。

本文版权归作者所有,未经授权不得转载。【作者:唐霜】【版权所有】唐霜 www.tangshuang.net【作者:唐霜】

默认false表示不自动加载polyfi【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】ll,此时,需要你自己手动在项目中引入p【关注微信公众号:wwwtangshuangnet】【转载请注明来源】olyfill,这在下面一节细讲。

【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】

entry时,需要你在代码中自己手写 【关注微信公众号:wwwtangshuangnet】import 'core-js'  这行的代码(注意只需要在整个应用中写一转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】次),但是在转码时,它会根据上文targ原创内容,盗版必究。【原创不易,请尊重版权】ets的情况,选择import对应的co转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】re-js模块,而不是把整个core-j【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。s都引入。

【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。

usage时,不需要你手写 【版权所有,侵权必究】import 'core-js' 但是它能自动识别你当前这个文件都用到哪【本文受版权保护】【版权所有,侵权必究】些core-js模块,然后自动在转码后的本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。代码中import进来。

原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。

当useBuiltIns为usage时,【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】preset-env会在文件开头插入类似【转载请注明来源】本文作者:唐霜,转载请注明出处。该图的语句,从而修改全局对象的原型链方法原创内容,盗版必究。【转载请注明来源】,这样做会污染全局

【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net

看上去有点麻烦,感觉好像直接用usage本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】不就好了么。但是实际上,在使用过程中你自转载请注明出处:www.tangshuang.net【转载请注明来源】然而然就会发现需要采用不同的策略。

著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。

corejs原创内容,盗版必究。

【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】未经授权,禁止复制转载。【版权所有,侵权必究】

承接useBuiltIns,当useBu本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。iltIns值为entry或usage时【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。,有效。它可以设置为:2,3,{ ver【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】sion, proposals }

【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【转载请注明来源】

因为目前core-js只有2和3两个版本原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。,以后可能会有更多版本。proposal【转载请注明来源】【本文受版权保护】s是指提案,在ES标准中,有些提案是铁定本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。会进入到标准的,虽然标准还没有发布,但是【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.netcore-js已经将它们做进去了。通过 【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net{ version: 3, propos【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】als: true } 就可以在代码中使【原创不易,请尊重版权】未经授权,禁止复制转载。用那些虽然没有被发布,但是肯定要进标准的未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。提案了。

本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】

include/exclude【转载请注明来源】

本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【转载请注明来源】转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。

只包含/不包含被列出的文件需要被转码。注本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】意,include如果被设置,那么只包含转载请注明出处:www.tangshuang.net【本文受版权保护】于这些文件中的文件才会被转码。

【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。

loose【原创不易,请尊重版权】

【本文受版权保护】著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。

这个选项设置为true时,它会尽可能的将【版权所有,侵权必究】【本文首发于唐霜的博客】ES6+代码转化为ES5标准代码,而非用【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】ES5去实现的ES6+代码,最核心的体现【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net就是class语法的实现。在ES5中,我转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net们通过SomeFunction.prot【转载请注明来源】转载请注明出处:www.tangshuang.netotype.someMethod来创建原【本文首发于唐霜的博客】【作者:唐霜】型链方法,而在ES6中它的实现完全不同。【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。当loose为true时,preset-未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。env将class语法转化为原型链的实现【未经授权禁止转载】【本文受版权保护】方式。

【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net

@babel/polyfill转载请注明出处:www.tangshuang.net

【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。

这个包是一个纯运行时的包,不是babel【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】插件。它的作用是直接改写全局变量,从而让本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。运行环境支持经过present-env转【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】码后的代码。

转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。

大部分情况下,preset-env转码后著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】的代码可以直接使用,但是在涉及到基于ge【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】nerator实现的语法时,例如 for著作权归作者所有,禁止商业用途转载。【作者:唐霜】…of 语法,则必须引入re【版权所有,侵权必究】原创内容,盗版必究。generator-runtime,因为未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】转码后的代码会生成regenerator本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。Runtime这个全局变量,而@babe著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。l/polyfill引入了core-js本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】和regenerator-runtime原创内容,盗版必究。【本文受版权保护】/runtime两个包。所以每次你安装完【转载请注明来源】【原创不易,请尊重版权】@babel/polyfill之后,它都【本文受版权保护】原创内容,盗版必究。会提示你,不要再用它了,直接用core-【转载请注明来源】著作权归作者所有,禁止商业用途转载。js和regenerator-runti未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】me/runtime就好了。

【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net【本文受版权保护】著作权归作者所有,禁止商业用途转载。

在我们设置preset-env的useB本文作者:唐霜,转载请注明出处。【未经授权禁止转载】uiltIns为false(默认值)时,本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】preset-env不会为我们自动引入p本文版权归作者所有,未经授权不得转载。【作者:唐霜】olyfill,我们要手动引入@babe【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.netl/polyfill,并会导致整个cor原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。e-js和regenerator-run【本文受版权保护】【本文受版权保护】time/runtime被打包进我们的项未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】目。这时,如果用webpack打包,bu【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。ndle文件的体积应该是最大的。

未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】【本文受版权保护】【未经授权禁止转载】

useBuiltIns为entry时,我【原创不易,请尊重版权】【版权所有,侵权必究】们手动引入@babel/polyfill【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net,比false好的是,它不会把所有的co【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.netre-js模块引入,而是只引入targe【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】ts需要的。虽然引入的模块比直接引入@b【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】abel/polyfill少,但总体而言【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.net,它还是会引入很多模块。

【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。

使用usage模式,preset-env【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net会自动帮你插入需要的core-js模块,【未经授权禁止转载】【本文受版权保护】不需要你手动import任何代码。缺点是未经授权,禁止复制转载。原创内容,盗版必究。:babel默认不会检测第三方依赖包代码【转载请注明来源】未经授权,禁止复制转载。,知会看当前文件中需要哪些polyfil原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。l,所以使用 usage 时,可能会出现引入第三方的代码包未注入【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。模块而引发bug。

原创内容,盗版必究。【原创不易,请尊重版权】未经授权,禁止复制转载。

@babel/plugin-transf原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netorm-runtime

【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】【作者:唐霜】

这是一个babel插件,使用这个插件的同【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。时,必须同时安装@babel/runti【未经授权禁止转载】【转载请注明来源】me这个包,而且必须是安装在depend【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。encies里面,而非devDepend【原创不易,请尊重版权】【本文首发于唐霜的博客】encies里面。

【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。

它有两个作用:著作权归作者所有,禁止商业用途转载。

【版权所有】唐霜 www.tangshuang.net【作者:唐霜】【未经授权禁止转载】本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net
  • 将preset-env所产生的helpe【作者:唐霜】【本文首发于唐霜的博客】rs函数提出到一个独立文件中,从而减少代【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。码量
  • 【转载请注明来源】【作者:唐霜】【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】
  • 建立运行时沙盒,避免像babel-pol【本文首发于唐霜的博客】未经授权,禁止复制转载。yfill一样,修改全局对象,造成全局污未经授权,禁止复制转载。【原创内容,转载请注明出处】
  • 【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net【本文受版权保护】

当我们在写一个独立的第三方库时,在做构建本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】的时候需要用到它。使用这个包之后,在我们本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。自己写的库的代码体系内,可以实现上述两个【原创内容,转载请注明出处】【本文首发于唐霜的博客】效果,这样有利于减少代码量,同时又避免污转载请注明出处:www.tangshuang.net【作者:唐霜】染全局。

【本文受版权保护】【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】

我们从它的配置项来看看这两个效果如何配置著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】

本文作者:唐霜,转载请注明出处。原创内容,盗版必究。【版权所有,侵权必究】【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】

corejs未经授权,禁止复制转载。

【原创内容,转载请注明出处】【版权所有,侵权必究】【转载请注明来源】

配置版本,传入corejs的值和同时安装【关注微信公众号:wwwtangshuangnet】【作者:唐霜】的@babel/runtime包是不一致未经授权,禁止复制转载。【原创不易,请尊重版权】的,你需要手动安装。例如,你传入2则需要【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】手动安装@babel/runtime-c本文版权归作者所有,未经授权不得转载。【作者:唐霜】orejs2,传入3则需要手动安装@ba原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。bel/runtime-corejs3,著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】并且,这三个包只安装对应的一个就好,它们未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。是互斥的。

【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】【本文首发于唐霜的博客】

corejs3有一些新特性,但是会增加代本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net码量。

【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。【作者:唐霜】【未经授权禁止转载】

只有传入corejs之后,上面提到的“建【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】立运行时沙盒”才会生效。它的效果实际上,【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】就是在当前文件使用独立的变量来使用某些E【本文首发于唐霜的博客】【版权所有】唐霜 www.tangshuang.netS特性。

【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】转载请注明出处:www.tangshuang.net

当配置了corejs为2时,文件顶部会被【本文首发于唐霜的博客】【本文受版权保护】翻译出上面这句代码,在整个文件中,Obj原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netect.keys接口会被替换为_Obje本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】ct$keys这个变量来进行,这样就可以原创内容,盗版必究。【原创不易,请尊重版权】避免污染全局的Object对象。

本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。【作者:唐霜】转载请注明出处:www.tangshuang.net

helpers本文作者:唐霜,转载请注明出处。

【原创不易,请尊重版权】【版权所有,侵权必究】【转载请注明来源】

是否要将所有helper函数提炼到另外一【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。个公共文件中。默认为true。

【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】

当使用@babel/plugin-tra转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】snform-runtime之后,原本b原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netabel会直接在文件中创建一个helpe【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】r函数,现在会采用require的方式,【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】从@babel/runtime中引入这些【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。函数,这样就可以减少代码量

【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】【原创内容,转载请注明出处】

一般情况下,@babel/plugin-【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。transform-runtime插件不本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】需要传入任何配置。在真正使用时,要配合@【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】babel/preset-env同时使用转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。,两者的corejs配置要一致,useE【转载请注明来源】【未经授权禁止转载】SModules也要一致。

【原创内容,转载请注明出处】【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

配置案例【原创不易,请尊重版权】

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

经过上文的分析只会,从特性、代码量等考虑【原创不易,请尊重版权】【转载请注明来源】,当我们要打包一个提供给其他团队使用的第本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net三方包时,我们来分析一下如下配置:

【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。【原创内容,转载请注明出处】
{
	"presets": [
		["@babel/preset-env", { "modules": false, "useBuiltIns": "usage", "corejs": 3 }]
	],
	"plugins": [
		["@babel/plugin-transform-runtime", { "corejs": 3 }]
	],
	"env": {
		"test": {
			"presets": [
				["@babel/preset-env", { "useBuiltIns": "usage", "corejs": 3 }]
			]
		}
	}
}

需要手动安装:【本文受版权保护】

原创内容,盗版必究。【本文首发于唐霜的博客】【版权所有,侵权必究】
# 构建时用
npm i -D @babel/plugin-transform-runtime @babel/preset-env @babel/core
# 运行时用
npm i core-js@3 @babel/runtime-corejs3 regenerator-runtime

这样,我们就可以定制我们自己的包了。【转载请注明来源】

本文作者:唐霜,转载请注明出处。【本文受版权保护】【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】

而如果是构建整个应用,则不需要使用@ba【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。bel/plugin-transform本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。-runtime,配置如下:

原创内容,盗版必究。未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】【本文受版权保护】
{
	"presets": [
		["@babel/preset-env", { "modules": false, "useBuiltIns": "usage", "corejs": 3 }]
	],
	"env": {
		"test": {
			"presets": [
				["@babel/preset-env", { "useBuiltIns": "usage", "corejs": 3 }]
			]
		}
	}
}

手动安装:本文作者:唐霜,转载请注明出处。

【作者:唐霜】著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net
# 构建时用
npm i -D @babel/preset-env @babel-core
# 运行时用
npm i core-js@3 regenerator-runtime

但是,使用 useBulitIns: &未经授权,禁止复制转载。【未经授权禁止转载】#8216;usage’ 不【作者:唐霜】【本文受版权保护】能保证所有的第三方库也使用了上面提到的构【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】建方法,在这种情况下,干脆直接将所有的p【本文受版权保护】未经授权,禁止复制转载。olyfill全部包含在应用中,从而避免转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】出现有些小问题。

转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】原创内容,盗版必究。
{
	"presets": [
		["@babel/preset-env", { "modules": false, "useBuiltIns": "entry", "corejs": 3 }]
	],
	"env": {
		"test": {
			"presets": [
				["@babel/preset-env", { "useBuiltIns": "entry", "corejs": 3 }]
			]
		}
	}
}

安装的包一样。并且,这个时候,你需要在你【本文首发于唐霜的博客】【版权所有,侵权必究】的 app 入口文件中增加如下两句:

转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】【版权所有】唐霜 www.tangshuang.net
import 'core-js'
import 'regenerator-runtime'

转码之后,import ‘c【本文首发于唐霜的博客】未经授权,禁止复制转载。ore-js’会被展开为很多【转载请注明来源】【作者:唐霜】行,但是它不会把整个core-js所有模【版权所有,侵权必究】【原创不易,请尊重版权】块引入,而是只引入targets配置中所【作者:唐霜】本文作者:唐霜,转载请注明出处。指出的环境所需要的模块。需要注意,不能将【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】这两个包加入到webpack的entry转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】中,否则无法产生babel-env应有的本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。效果。

【本文受版权保护】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。

总之,不推荐直接不配置useBuiltI未经授权,禁止复制转载。原创内容,盗版必究。ns而直接import ‘@【本文首发于唐霜的博客】【版权所有,侵权必究】babel/polyfill’转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net;的做法。

本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。

2019-11-07 10446

为价值买单,打赏一杯咖啡

本文价值104.46RMB
已有6条评论
  1. slw 2020-03-24 15:25

    希望你更新一下自己的配置讲解,你可能误解了

  2. 和振峰 2020-01-09 15:22

    @babel/plugin-transform-runtime 为什么在项目中不建议使用  
    corejs  使用 2 一般就够了吧

    • 和*峰 2020-01-09 15:29

      @babel/plugin-transform-runtime又这么多好处,干嘛必须在第三方包用 ,自己项目中不是更好

      • 否子戈 2020-01-10 18:12

        自己的第三方包项目

  3. 神奇海螺 2019-12-23 18:58

    帮助我弄清楚了心中的疑问,很实用。我想用于团队内容分享(注明出处),可以么?

    • 否子戈 2019-12-23 19:15

      可以,不过里面的内容还需要你自己甄别,我后来发现自己推荐的配置方式并不好,你可以根据自己的情况调整