「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!(二)

简介: 「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!

「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!(一)https://developer.aliyun.com/article/1426257


4. 打包JavaScript代码

介绍Webpack对JavaScript代码的打包和压缩,包括Babel转译、JS模块化、代码分离等技术。

Babel转译

Webpack可以对JavaScript代码进行打包和优化,其中一些技术包括Babel转译、JS模块化、代码分离等。

Babel转译Webpack中常用的技术之一,它可以将ES6/7/8代码转换为ES5代码,以兼容一些老旧浏览器。为了使用Babel,需要在Webpack中添加Babel Loader,示例代码如下:

{
    test: /\.js$/,
    exclude: /node_modules/,
    loader: 'babel-loader',
    options: {
        presets: ['@babel/preset-env']
    }
}

JS模块化

JS模块化也是Webpack的一个核心功能,Webpack可以将多个模块打包成一个文件加粗样式,同时使用ES6的import/export语法来管理模块,避免全局命名冲突的问题。示例代码如下:

// main.js
import { hello } from './message';
document.write(hello());
// message.js
export function hello() {
    return "Hello, world!";
}

代码分离

代码分离是Webpack的另一个重要功能,它可以将JS代码分成多个bundle,使应用程序更快地加载。Webpack提供了两种代码分离方法:同步代码分离和异步代码分离。同步代码分离可以通过optimization.splitChunks进行配置,将多个入口文件公共部分提取成单独的chunk,这样就可以避免重复加载同一段代码,从而提高应用的性能。

示例代码如下:

optimization: {
    splitChunks: {
        chunks: 'all'
    }
}

异步代码分离将异步加载的代码单独打包成chunk,可以使用Webpack的动态导入语法(dynamic import)来实现。示例代码如下:

import("./module").then(module => {
});

除了上述技术,Webpack还提供了各种其他优化策略,包括代码压缩、缓存等。其中,代码压缩可以通过使用UglifyJSPlugin插件来完成,示例代码如下:

const UglifyJSPlugin = require('uglifyjs-webpack-plugin');
module.exports = {
    optimization: {
        minimize: true,
        minimizer: [new UglifyJSPlugin()]
    }
};

缓存是另一个优化策略,Webpack可以通过hash、chunkhash、contenthash等方式来对打包后的文件进行缓存,避免文件重复打包和传输,提高用户体验。示例代码如下:

output: {
    filename: '[name].[hash].js',
    chunkFilename: '[name].[chunkhash].js',
},

综上所述,WebpackJavaScript代码的打包和压缩涉及多个技术和方法,其中一些技术包括Babel转译、JS模块化、代码分离、代码压缩和缓存等。在实际应用中,可以根据具体情况选择使用不同的技术和方法来完成代码打包和优化。

5. 打包样式表

介绍Webpack对CSS、Less、Sass等样式表的打包和压缩,包括style-loader、css-loader、postcss-loader等loader的使用方法。

Webpack可以将CSS、Less、Sass等样式表文件打包成一个单独的CSS文件,并且支持对CSS文件进行压缩。

在Webpack中,我们可以使用一些loader来处理不同类型的样式表文件,例如:

  • style-loader将CSS代码注入到HTML文档中的标签中。
  • css-loader用于解析CSS文件,并将其转化为模块,以便在JavaScript文件中引入。
  • less-loader用于将Less文件编译成CSS文件。
  • sass-loader用于将Sass文件编译成CSS文件。

除此之外,我们也可以使用postcss-loader来对CSS文件进行后处理,例如添加浏览器前缀、压缩等。

下面是一个使用Webpack处理CSS、Sass和Less文件的例子:

// webpack.config.js
const path = require('path');
module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: ['style-loader', 'css-loader', 'postcss-loader'],
      },
      {
        test: /\.less$/,
        use: ['style-loader', 'css-loader', 'postcss-loader', 'less-loader'],
      },
      {
        test: /\.sass$/,
        use: ['style-loader', 'css-loader', 'postcss-loader', 'sass-loader'],
      },
    ],
  },
};

在这个例子中,我们定义了三个loader规则,分别用于处理CSS、Sass和Less文件。postcss-loader会在每个文件的CSS转换完成后对CSS进行后处理。

值得注意的是,这里我们使用了style-loader将CSS代码注入到HTML文档中,但是这会造成页面刷新时样式会闪烁。对此,我们可以使用mini-css-extract-plugin将CSS文件提取到单独的文件中,在页面刷新时样式不会被重新加载。

Webpack提供了很多loader和插件,可以帮助我们更好地处理JavaScript、CSS、图片和其他资源文件。使用它们可以使我们的前端开发工作更加高效和便捷。

6. 打包图片和字体

介绍Webpack对图片和字体的打包和压缩,包括file-loader、url-loader等loader的使用方法。

在Webpack中,我们可以使用一些loader来处理图片、字体等资源文件,例如:

  • file-loader用于将文件输出到指定的文件夹中,并返回相对路径或URL。
  • url-loader将小于指定大小的文件转换为DataURL,大于指定大小的文件仍旧使用file-loader来处理。

下面是一个使用Webpack处理图片和字体文件的例子:

// webpack.config.js
const path = require('path');
module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [
      {
        test: /\.(png|jpe?g|gif|svg)$/i,
        use: [
          {
            loader: 'url-loader',
            options: {
              limit: 8192,
            },
          },
        ],
      },
      {
        test: /\.(woff|woff2|eot|ttf|otf)$/i,
        use: [
          {
            loader: 'file-loader',
          },
        ],
      },
    ],
  },
};

在这个例子中,我们定义了两个loader规则,用于处理图片和字体文件。url-loader会将小于8KB的图片文件转换为DataURL,大于8KB的图片文件将使用file-loader处理,输出到指定的文件夹中。file-loader也会处理字体文件,并输出到指定的文件夹中。

值得注意的是,在使用url-loader时,我们可以通过设置options中的limit参数来控制文件大小的阈值,小于该阈值的文件会被转换为DataURL,大于该阈值的文件会被转换为文件并使用file-loader处理。

Webpack提供了很多loader和插件,可以帮助我们更好地处理JavaScript、CSS、图片和其他资源文件。使用它们可以使我们的前端开发工作更加高效和便捷。


「零基础」掌握Webpack:10个必学技巧,为前端项目保驾护航!(三)https://developer.aliyun.com/article/1426259

相关文章
|
3月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
187 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
5月前
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
180 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
4月前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
175 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
4月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
291 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
3月前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
4月前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
154 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
5月前
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
162 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
4月前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
105 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
5月前
|
缓存 前端开发 Android开发
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
261 12
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
|
5月前
|
缓存 前端开发 IDE
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
95 0
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
下一篇
oss创建bucket