JS模块化-ES6的模块化

2021-04-06 11:26

阅读:691

标签:exp   技术   package   fill   运行   兼容   如何   mod   put   

ES6-babel-Browserify使用教程

四个js文件:

技术图片

 

 

 utils.js

技术图片

 

 

 products.js     (依赖于utils.js)

技术图片

 

 

users.js

技术图片

 

 

 main.js

技术图片

 

 

 此时直接在终端输入:node js/main.js   可能会报错:

表示不支持import(说明浏览器更不可能支持)

nodejs不兼容es6标准的模块定义语法

 

解决方法一:babel-node

步骤:

(1)在终端输入:pm -i babel-cli -g

(2)安装语法插件:npm i babel-preset-es2015 -save

(3)在当前项目的根目录下新建   .babelrc  文件并配置:

{
  "presets":[
    "es2015"
  ],
  "plugins":[]
}

 此时再在终端输入 :  babel-node js/main.js    即可正确执行main.js中的代码

技术图片

 

 

解决方案二 :将ES6转换成ES5(依然是babel工具)

步骤:

(1)当前项目找到package.json  找到"scripts"项,向里面添加命令:

"build":"babel   js   -d    build --out-dir es5_build"
//意思是将js文件夹下所有的js文件转换成es5版本,并且保存到es5_build文件夹下

 技术图片

 

 (2)这样在每次运行新的项目之前,在终端输入 npm run build     会自动执行package.json下的script指令,会多出一个es5_build文件夹,包含转换结束后的文件:

技术图片

 

此时再直接运行node es5_build/main.js就不会报不支持import的错误了:

技术图片

 

到这一步,就可以让服务端接受ES6标准的模块化语法了。

 

解决方案三:如何让浏览器端也支持ES6模块规范

步骤一

安装工具:

(1)打包工具:

    npm i -g webpack-cli babel-cli

(2)ES2015两个工具:

    npm i babel-preset-es2015 babel-loader

(3)

    npm i --save-dev babel-polyfill

(4)

    npm i -save babel-core

    

步骤二:

新建webpack.config.js文件并进行配置:

module.exports={
  entry:["babel-polyfill","./js/main.js"],
  // 把js/main.js变成兼容代码
  output:{
    path:__dirname+"/dist",
    filename:"main.js"
    // 将编译打包后的mian.js保存到当前目录下dist文件夹下的main.js
  },
  module:{
    rules:[{
      test:/.js$/,
      // 使用babel-loader工具将制定目录下的所有js文件都加载下来
      loader:"babel-loader"
    }]
  }
}

如下:

技术图片

 

 此时es6文件夹内有:js文件夹,node_module文件夹,package.jsonwebpack.config.js

在webpack.config.js同级目录下终端中运行:webpack

*** 这个命令需要安装webpack      npm install webpack -g(也有可能需要更新:npm install babel-loader@7  )

运行结束以后,当前文件夹中会出现/dist文件夹,包含了一个main.js文件:

技术图片

 

 此时在当前项目下新建HTML文件并引入/dist文件夹下的main.js就可以正确执行了:

技术图片

 

 技术图片

 

 

由此可见,通过使用babel和webpack两个工具,可以实现es6的标准代码转换成浏览器所支持的es5的代码,并且进行了压缩和合并

 

方案三:浏览器插件解决

    

 

JS模块化-ES6的模块化

标签:exp   技术   package   fill   运行   兼容   如何   mod   put   

原文地址:https://www.cnblogs.com/codexlx/p/12495023.html


评论


亲,登录后才可以留言!