当前位置: 首页 > article >正文

5.学习webpack配置 babel基本配置

babel是一个javascript编译工具,其主要功能是将新版本的JavaScript代码(如es6+)转换为旧版本的代码(如es5),以便能够在旧版本的浏览器或环境中运行。一般配合webpack使用。

使用npm i -D @babel/core @babel/preset-env babel-loader core-js安装babel相关依赖

配置webpack.config.js

我们需要在webpack.config.js中配置babel相关内容

// nodejs的模块 帮助我们拼接路径
const path = require("path");
// 引入html插件
const HTMLWebPackPlugin = require("html-webpack-plugin");
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
// webpack中所有的配置信息 都应该写在module.exports中
module.exports = {
  //指定入口文件
  entry: "./src/index.ts",
  // 指定打包文件所在的目录
  output: {
    //指定打包后的目录
    path: path.resolve(__dirname, "dist"),
    // 打包后文件的名字
    filename: "bundle.js",
  },
  mode: "development", // 设置mode
  // 指定webpack打包时 使用的模块
  module: {
    // 指定要加载的规则
    rules: [
      {
        // test指定的是规则生效的文件
        test: /\.ts$/, //匹配所有的以ts结尾的文件
        use: [
          // 配置babel
          {
            // 指定加载器
            loader: "babel-loader",
            // 设置babel
            options: {
              //设置预定义的环境
              presets: [
                [
                  // 指定环境插件
                  "@babel/preset-env",
                  // 配置信息
                  {
                    // 指定浏览器的版本
                    targets: {
                      chrome: "58",
                      ie: "11",
                    },
                    // 指定corejs的版本
                    corejs: "3",
                    // 使用corejs的方法 "usage" 表示按需加载
                    useBuiltIns: "usage",
                  },
                ],
              ],
            },
          },
          "ts-loader",
        ], //用tsloader来处理以ts结尾的文件
        exclude: /node-modules/, //排除文件
      },
    ],
  },

  // 配置webpack插件
  plugins: [
    new HTMLWebPackPlugin({
      template: "./src/index.html",
    }),
    new CleanWebpackPlugin(),
  ],
  resolve: {
    extensions: [".ts", ".js"],
  },
  // npm i -D @babel/core @babel/preset-env(定义好了很多环境)
  // npm i -D @babel/core @babel/preset-env babel-loader core-js
};

当我们兼容某些旧版本的浏览器时候,比如ie11,他不兼容es6的低版本代码,所以执行npm run build的时候会生成低版本的javascript代码

打包以后使用const定义的obj就会发现已经改成了var了 因为低版本的javascript是没有const let相关语法的。

corejs

就是javascript的补丁,在遇到低版本的浏览器的时候,他会作为工具箱,给低版本的javascript提供某些高版本的功能如Promise

比如当我们的项目使用了Promise,没有安装corejs,即使是有babel也是没用的,安装了corejs会解决这一问题

当我们尝试打印Promise 并且在webpack.config.js中添加了ie11以及corejs的配置后,编译后文件就会写入corejs自己封装的Promise,

但是如果我们运行在ie11的浏览器环境下,会发现打印依然出错,无论使不使用Promise,因为我门webpack默认编译为一个自执行的箭头函数,在低版本的javascript语法中,是没有箭头函数这个语法的,所以我们需要在webpack.config.js中配置一下。

environment: {

arrowFunction: false,

},

  output: {
    //指定打包后的目录
    path: path.resolve(__dirname, "dist"),
    // 打包后文件的名字
    filename: "bundle.js",
    environment: {
      arrowFunction: false,
    },
  },

这样我们打包出来的文件就不是箭头函数了

 


http://www.kler.cn/a/452665.html

相关文章:

  • H5 与 WebView 的双向通信实现详解
  • Docker 镜像加速访问方案
  • 004-spring-注解aop的使用
  • 【ES6复习笔记】模板字符串(3)
  • 【人工智能】使用Python构建推荐系统:从协同过滤到深度学习
  • Django 模型中使用选择(choices):全面指南
  • uni-app 跨端开发精美开源UI框架推荐
  • 编码转换(实例)
  • 2024最新教程Mac安装双系统
  • ensp 基于EASY IP的公司出口链路配置
  • 微服务分布式(二、注册中心Consul)
  • 【全栈开发】----用pymysql库连接MySQL,批量存入
  • 浙江肿瘤医院病理库存储及NAS共享存储(磁盘阵列)方案-Infortrend普安科技
  • SQL执行计划解读
  • 【每日学点鸿蒙知识】获取是否有网接口、获取udid报错、本地通知、Json转Map、Window10安装Hyper-v
  • 《网络对抗》—— Web安全基础实践
  • 【山西长治】《长治市市直部门政务信息化建设项目预算编制规范和预算编制标准》(长财行[2022]25号)-省市费用标准解读系列32
  • 【安全编码】Web平台如何设计防止重放攻击
  • MyBatis中动态SQL执行原理
  • AI开发:使用支持向量机(SVM)进行文本情感分析训练 - Python
  • Redis 安装部署[主从、哨兵、集群](linux版)
  • 解决 fatal: detected dubious ownership in repository at ‘XXXX‘ 问题
  • 《计算机组成及汇编语言原理》阅读笔记:p86-p115
  • 理解并使用 Linux 内核的字符设备
  • 鸿蒙开发面试准备和经验
  • RabbitMQ中的普通Confirm模式:深入解析与最佳实践