我是靠谱客的博主 激昂灯泡,最近开发中收集的这篇文章主要介绍webpack怎么将es6转成es5的模块,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

万恶的IE遗臭万年仍然需要填坑

  • ie标准对html/css甚至js的规范简直相差甚远,所以,一般要解决的兼容问题很大一部分是为了解决ie的不兼容,虽然目前流行的ES6语法及规范将IE的考虑抛弃掉,默认放弃对IE的治疗,但是IE的兼容仍然是个问题!即使IE的使用率已经不到1%的市场占比。
  • 我们使用着舒服的ES6规范但是为IE又很头疼怎么办呢?Webpack开发了非常厉害的打包转换功能:转ES5!

随便来个ES6代码

  • 就写个let声明和遍历:
console.log("webpack 1");
let date = ["hello", "world", "this", "is", "es6", "code"];

((theDate) => {
    theDate.forEach(item => console.log(item));
})(date)
登录后复制

1.png

这是在Chrome浏览器里的结果

2.png

这是在火狐浏览器的结果:

3.png

这是ie11浏览器的结果:
4.png

完全不出意料哈!我们来转一转。

  • 这里我们先做一个修改,用导入的办法把ES6代码挪到打包的js代码文件中:
    原index.js:
console.log("webpack 1");
let fun = () => {
    let date = ["hello", "world", "this", "is", "es6", "code"];
    date.forEach(item => console.log(item));
}
//fun() //结果依然刚才一样
export default fun;//es6导出函数,es6模块化知识
登录后复制

Can’t find @babel/core 问题

  • 以前安装打包需要的插件或者说是工具包:
npm install babel-core babel-loader babel-preset-es2015 --save-dev
#因为是开发测试环境,就加了dev,各自根据需要更改保存参数
登录后复制
  • 没错,因为版本兼容问题,最新的8.x版本babel-loader读取babel-core发生了改变,因此我们要安装对应匹配的版本:
#webpack 4.x | babel-loader 8.x | babel 7.x 最新版本
npm install -D babel-loader @babel/core @babel/preset-env
#webpack 4.x | babel-loader 7.x | babel 6.x 版本
npm install -D babel-loader@7 babel-core babel-preset-env webpack
登录后复制
  • 我这里使用的是7.x版本:

5.png

  • 创建babel工具的配置文件:.babelrc,设定转码规则
{
    "presets": [
        "es2015"
    ], 
    "plugins": []
}
登录后复制

6.png

  • webpack.config.js配置打包规则:
module: {
    rules: [{
        test: /.js$/,
        use: 'babel-loader',
        exclude: /node_modules/
    }]
}
登录后复制

7.png

  • webpack执行,生成test.html

8.png

  • 浏览器的效果:

Chrome

9.png

IE

10.png

代码成功在IE上运行了

  • 我们再看看打包转换成的es5长啥样

11.png

es6转es5到此结束。

【相关推荐:javascript视频教程、编程视频】

以上就是webpack怎么将es6转成es5的模块的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是激昂灯泡为你收集整理的webpack怎么将es6转成es5的模块的全部内容,希望文章能够帮你解决webpack怎么将es6转成es5的模块所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(97)

评论列表共有 0 条评论

立即
投稿
返回
顶部