Skip to content

a parser for explorer what feature your js project has used

Notifications You must be signed in to change notification settings

ZhechenLi/next-polyfill

Repository files navigation

Next Polyfill

Next Polyfill 提供了一个体积更小,更灵活的 web 端 polyfill 方案

安装

npm i --save-dev next-polyfill

使用

Next Polyfill 做的事情很简单,读取你的代码并解析出你使用的 js 语言特性,生成对应 ployfill.io 对应的 url(你也可以替换成自己实现的版本)

其中 parser 的用法如下:

import {parse} from 'next-polyfill';

const code = `
    Object.entries({a: 1})
`;

parse(code, {}, (err, result)=>{
    if(err) throw err;

    console.log(result) 
    // Set {
    //    'es7.object.entries',
    //    'es6.array.iterator',
    //    'web.dom.iterable' 
    //}

});

可以在回调的参数 result 内取到当前代码所使用的 JavaScript 语法特性

在 Webpack 中使用

定义 webpack.config.js

let NextPolyfillWebpackPlugin = require('next-polyfill').NextPolyfillWebpackPlugin
module.exports = {
    plugins: [
        // ...
        new NextPolyfillWebpackPlugin()
        // ...
    ]
}

接着定义我们的 entry

console.log('aloha');

[].includes(1);

NextPolyfillWebpackPlugin 会自动在输出的 html 模板处添加 script 标签,输出如下

<script src="https://polyfill.io/v3/polyfill.min.js?feature=default%2CObject.defineProperty%2CSymbol%2CSymbol%2CObject.create%2CFunction.prototype.bind%2CString.prototype.includes%2CArray.prototype.includes&amp;unknown=polyfill&amp;flags=gated"></script>

可以看到在 chrome 72 下 polyfill 体积仅为 496b,几乎只包含请求头的大小

image-20190313224109953

image-20190313223935661

接着让我们把 UA 设置成 IE9

image-20190313224322205

image-20190313224309694

可以看到在只有一行代码的情况下 polyfill 的体积依然达到了2.7 k,优化的效果相当明显。

如果使用传统的方案,即使用户使用的是最新的浏览器,也不得不带上冗余的 2.7k 的 polyfill。

而且实现这一切只需要你增加一个 webpack plugin,剩下的 Next polyfill 会帮你处理

webpack example 的详细的代码请看

License

MIT

About

a parser for explorer what feature your js project has used

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published