Webpack中loader打包各种文件的方法实例


Posted in Javascript onSeptember 03, 2019

前言

使用webpack时,在main.js文件中直接使用如下代码导入了style.css文件,控制台中显示如下错误:You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file.

import './css/style.css';

原因是,webpack中默认只能打包.js类型文件,无法打包其他类型文件。如果要打包非.js类型文件,需要手动安装一些第三方loader加载器。

以下为各种文件类型打包实例:

处理css文件

方式一

在项目中用npm命令本地安装style-loader和css-loader两个包

npm install style-loader css-loader --save--dev

在引用style.css文件时,将import './css/style.css';代码改为以下代码:

import 'style-loader!css-loader!./style.css'")'; //先经过css-loader和style-loader处理

重新用webpack打包

npm run dev

这种方式的缺点是,当需要引入多个css文件,每次引入时都需要加style-loader!css-loader!,比较麻烦,因此推荐使用以下方式:

方式二

在项目中用npm命令本地安装style-loader和css-loader两个包

npm install style-loader css-loader --save--dev

打开webpack.config.js文件,在里面新增一个配置节点module,在module对象中,有一个rules属性,它是一个数组,里面存放了所有第三方文件匹配和处理规则。如下代码匹配处理css文件:

module: { // 配置所有第三方loader 模块
 rules: [ // 第三方模块的匹配规则
  { test: /\.css$/, use: ['style-loader', 'css-loader'] }, // 处理 CSS 文件的 loader
 ]
 }

注意:此处'style-loader'和'css-loader'顺序不可替换。因为use中处理顺序为从后往前。先用css-loader对css文件进行处理,将处理后的结果交给style-loader作进一步处理,处理为webpack可以进行打包的数据。

引入style.css文件

import './css/style.css';

重新用webpack打包

npm run dev

以下所有其他类型文件的打包同方式二

处理less文件

在项目中用npm命令本地安装style-loader和css-loader和less-loader和less三个包(若已有style-loader和css-loader则不必再安装这两个)

npm install style-loader css-loader less-loader less --save--dev

打开webpack.config.js文件,在节点module中rules属性数组中,新增如下less的规则:

{ test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] } // 处理 less 文件的 loader

引入style.less文件

import './css/style.less';

重新用webpack打包

npm run dev

处理scss文件

在项目中用npm命令本地安装style-loader和css-loader和sass-loader和node-sass四个包(若已有style-loader和css-loader则不必再安装这两个)

npm install style-loader css-loader sass-loader node-sass --save--dev

打开webpack.config.js文件,在节点module中rules属性数组中,新增如下scss的规则:

{ test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] } // 处理 less 文件的 loader

引入style.scss文件

import './css/style.lcss';

重新用webpack打包

npm run dev

处理url地址

例如,在css样式中使用background-image:url('...'),webpack默认无法处理url,因此也需要手动安装第三方loader

在项目中用npm命令本地安装url-loader和file-loader两个包

npm install url-loader file-loader --save--dev

打开webpack.config.js文件,在节点module中rules属性数组中,新增如下的规则:

{ test: /\.(jpg|png|gif|bmp|jpeg)$/, use: 'url-loader' }, // 处理 图片路径的 loader
{ test: /\.(ttf|eot|svg|woff|woff2)$/, use: 'url-loader' }, // 处理 字体文件的 loader

重新用webpack打包

npm run dev

处理ES6高级语法

webpack默认只能处理一部分的ES6语法,对于一些更高级的ES6语法,webpack无法处理,如下代码用webpack打包会报错。

class Person {
	static info = {name:'zlx',age:18}
};
console.log(Person.info);

webpack需要借助于第三方的 loader,这里使用Babel,将高级的ES6语法转为低级的语法之后,再将结果进行打包。

用npm命令安装如下包:

npm i babel-core babel-loader babel-plugin-transform-runtime -D
npm i babel-preset-env babel-preset-stage-0 -D

打开webpack.config.js文件,在节点module中rules属性数组中,新增如下的规则:

{ test: /\.js$/, use: 'babel-loader', exclude: /node_modules/ }, // exclude是防止node_modules中的js文件被打包

在项目的 根目录中,新建一个 叫做 .babelrc  的Babel 配置文件,这个配置文件,属于JSON格式。里面写入如下代码:

{
 "presets": ["env", "stage-0"],
 "plugins": ["transform-runtime"]
}

重新用webpack打包

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
Z-Blog中用到的js代码
Mar 15 Javascript
在textarea中显示html页面的javascript代码
Apr 20 Javascript
JavaScript 闭包深入理解(closure)
May 27 Javascript
用JS将搜索的关键字高亮显示实现代码
Nov 08 Javascript
JavaScript删除指定子元素代码实例
Jan 13 Javascript
JS返回iframe中frameBorder属性值的方法
Apr 01 Javascript
懒加载实现的分页&&网站footer自适应
Dec 21 Javascript
Angular.js自定义指令学习笔记实例
Feb 24 Javascript
使用jQuery,Angular实现登录界面验证码详解
Apr 27 jQuery
jQuery zTree树插件动态加载实例代码
May 11 jQuery
Angular.js中window.onload(),$(document).ready()的写法浅析
Sep 28 Javascript
微信小程序 上传头像的实例详解
Oct 27 Javascript
JavaScript 预解析的4种实现方法解析
Sep 03 #Javascript
JavaScript自动生成 年月范围 选择功能完整示例【基于jQuery插件】
Sep 03 #jQuery
js tab栏切换代码实例解析
Sep 03 #Javascript
解决layui 三级联动下拉框更新时回显的问题
Sep 03 #Javascript
Node.js学习教程之Module模块
Sep 03 #Javascript
vue动态绘制四分之三圆环图效果
Sep 03 #Javascript
微信小程序拼接图片链接无底洞深入探究
Sep 03 #Javascript
You might like
sphinx增量索引的一个问题
2011/06/14 PHP
Javascript 不能释放内存.
2006/09/07 Javascript
JavaScript 面向对象之命名空间
2010/05/04 Javascript
javascript中全局对象的isNaN()方法使用介绍
2013/12/19 Javascript
JS、DOM和JQuery之间的关系示例分析
2014/04/09 Javascript
AngularJS 在同一个界面启动多个ng-app应用模块详解
2016/12/20 Javascript
滚动条的监听与内容随着滚动条动态加载的实现
2017/02/08 Javascript
小程序红包雨的实现示例
2019/02/19 Javascript
vue动态绑定class的几种常用方式小结
2019/05/21 Javascript
Vue 的双向绑定原理与用法揭秘
2020/05/06 Javascript
vuex页面刷新导致数据丢失的解决方案
2020/12/10 Vue.js
Vue中避免滥用this去读取data中数据
2021/03/02 Vue.js
Python开发的实用计算器完整实例
2017/05/10 Python
启动Atom并运行python文件的步骤
2018/11/09 Python
Python正则表达式和元字符详解
2018/11/29 Python
django数据库自动重连的方法实例
2019/07/21 Python
简单了解python中的f.b.u.r函数
2019/11/02 Python
Python实现发票自动校核微信机器人的方法
2020/05/22 Python
python中pyplot基础图标函数整理
2020/11/10 Python
基于CSS3的animation属性实现微信拍一拍动画效果
2020/06/22 HTML / CSS
连卡佛中国官网:Lane Crawford中文站
2018/01/27 全球购物
美国流行背包品牌:JanSport(杰斯伯)
2018/03/02 全球购物
I.T集团香港官方商城:ITeSHOP.com Hong Kong
2019/02/15 全球购物
医学专业毕业生个人的求职信
2013/12/04 职场文书
大一新生军训时的自我评价分享
2013/12/05 职场文书
关爱留守儿童倡议书
2014/04/15 职场文书
求职信范文大全
2014/05/26 职场文书
教师个人读书活动总结
2014/07/08 职场文书
2014迎接教师节演讲稿
2014/09/10 职场文书
机关干部四风问题自我剖析及整改措施
2014/10/26 职场文书
同学聚会通知书
2015/04/20 职场文书
大卫科波菲尔读书笔记
2015/06/30 职场文书
修改MySQL的数据库引擎为INNODB的方法
2021/05/26 MySQL
PHP中多字节字符串操作实例详解
2021/08/23 PHP
Apache Linkis 中间件架构及快速安装步骤
2022/03/16 Servers
Windows Server 2016 配置 IIS 的详细步骤
2022/04/28 Servers