首页 > 其他 > 详细

Babel转码器

时间:2020-03-24 16:48:30      阅读:59      评论:0      收藏:0      [点我收藏+]

Babel转码器

  • 将ES6转换为ES5的转码器,使代码在现在环境中执行

  • 需要在项目目录中进行安装

    • npm i @babel/core -s -d

配置文件.babelrc

  • 使用babel的第一步,就是在项目根目录中配置此文件

  • 用来设置转码规则和插件

  • 按需安装规则集和插件,并将其加入.babelrc

    • {
         "preset":[],
         "plugins":[]
      }

命令行转码

  • Babel提供命令行工具@babel/cli,用于命令行转码

  • 安装

    • npm i --save-dev @babel/cli
  • 使用

    • #将指定文件直接转码输出
      npx babel example.js
      ?
      #将指定文件转码,结果写入另一文件
      # --out-file 或 -o 参数指定输出文件
      npx babel example.js --out-file compiled.js
      # 或者
      npx babel example.js -o compiled.js
      ?
      #整个目录转码
      #--out-dir 或 -d参数指定输出目录
      npx babel src --out-dir lib
      #或
      npx babel src -d lib
      ?
      #-s参数生成source map文件
      npx babel src -d lib -s

babel-node

  • 支持node的REPL环境的所有功能,且可以直接运行ES6代码

    • npm i --save-dev @babel/node
      # 执行babel-node进入REPL环境
      npm babel-node
      #直接运行ES6脚本
      npm babel-node es6.js

@babel/register 模块

  • 改写require命令,每当使用其加载加载.js.jsx.es.es6后缀名的文件,就会先用 Babel 进行转码。

    • npm i -s-d @babel/register
  • 只对引入的文件转码,并不会对当前文件转码

  • 写在require引入文件之前

babel API

  • 当使用Babel的api进行转码,需要使用@babel/core模块

  • require引入@babel/core模块时返回一个对象,此对象中的api可以用来转码

    var babel = require(‘@babel/core‘);
  • transform

    • 第一个参数是字符串,表示需要转码的es6代码

    • 第二个参数是转换的配置对象

    • 返回值中包含:map,code,ast

    • code为转换后的代码

    babel.transform()

@babel/polyfill

  • babel默认只转换es6中的新句法,不转换其新的api

    • 安装

      npm install --save-dev @babel/polyfill
    • 使用,在脚本文件头部

      import ‘@babel/polyfill‘
      //或者
      require (‘@babel/polyfill‘)

用于浏览器环境

  • Babel 也可以用于浏览器环境,使用@babel/standalone模块提供的浏览器版本,将其插入网页

    • <script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
      //或者下载后按路径导入
      <script type=‘text/babel‘>
      </script>

Babel转码器

原文:https://www.cnblogs.com/ashen1999/p/12559732.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!