What is the difference between polyfill and transpiler?

后端 未结 5 900
离开以前
离开以前 2021-02-01 02:37

What is the difference between a polyfill and transpiler?

I often read the same term used in similar context.

5条回答
  •  面向向阳花
    2021-02-01 02:40

    Polyfill

    The word polyfill is an invented term (by Remy Sharp) used to refer to taking the definition of a newer feature and producing a piece of code that’s equivalent to the behavior, but is able to run in older JS environments.

    For example:

    ES1 defines a method called isNaN(value) to determines whether a value is an illegal number (Not-a-Number).

    ES6 defines a method called Number.isNaN(value) too determines whether a value is NaN (Not-a-Number).

    If you notice, Number.isNaN() is not supported in every browser, so for this purpose you can polyfill the method. Not all new features are fully polyfillable. Sometimes most of the behavior can be polyfilled, but there are still small deviations. You should be really, really careful in implementing a polyfill yourself, to make sure you are adhering to the specification as strictly as possible. Or better yet, use an already vetted set of polyfills that you can trust, such as those provided by ES5-Shim and ES6-Shim.

    // These method is a sample of making polyfill 
    if (!Number.isNaN) {
        Number.isNaN = function isNaN(x) {
            return x !== x;
        };
    }
    

    Transpile

    There’s no way to polyfill new syntax that has been added to the language. The new syntax would throw an error in the old JS engine as unrecognized/invalid. So the better option is to use a tool that converts your newer code into older code equivalents. This process is commonly called “transpiling” a term for transforming + compiling.

    There are several important reasons you should care about transpiling:

    1. The new syntax added to the language is designed to make your code more readable and maintainable. The older equivalents are often much more convoluted. You should prefer writing newer and cleaner syntax, not only for yourself but for all other members of the development team.
    2. If you transpile only for older browsers, but serve the new syntax to the newest browsers, you get to take advantage of browser performance optimizations with the new syntax. This also lets browser makers have more real-world code to test their implementations and optimizations on.
    3. Using the new syntax earlier allows it to be tested more robustly in the real world, which provides earlier feedback to the Javascript committee (TC39). If issues are found early enough, they can be changed/fixed before those language design mistakes become permanent.

    There are quite a few great transpilers for you to choose from. Here are some good options at the time of this writing:

    1. Babel (formerly 6to5): Transpiles ES6 and above into ES5
    2. Traceur: Transpiles ES6, ES7, and beyond into ES5

提交回复
热议问题