首页 > 其他分享 >webpack中的loader

webpack中的loader

时间:2022-09-03 19:44:34浏览次数:62  
标签:处理 js webpack css loader 打包

1.loader概述

在实际开发过程中,webpack默认只能打包处理 .js 后缀名结尾的模块,其他非.js后缀名结尾的模块,webpack默认处理不了,需要调用loader加载器才可以正常打包,否则会报错!

loader加载器的作用:协助webpack打包处理特定的文件模块。比如:

css-loader 可以打包处理.css相关的文件

css-loader 可以打包处理.less相关的文件

babel-loader可以打包处理webpack无法处理的高级JS语法

 2.loader处理流程

3.打包处理CSS文件

  1.运行 npm i [email protected] [email protected] -D

  2.在webpack.gonfig.js的module->rules数组中,添加loader规则如下:

module:{ //所有第三方文件模块的匹配规则
    rule:[ //文件后缀名的匹配规则
        {test:/\.css$/,use:['style-loader','css-loader']}
    ]
}

  其中,test表示匹配的文件类型,use表示对应要调用的loader

  注意:

  use数组中指定的loader顺序是固定的

  多个loader的调用顺序是:从后往前调用  

 

   1.webpack默认只能打包处理.js文件,处理不了其它的后缀的文件

  2.由于代码中包含了index.css这个文件,因此webpack默认处理不了

  3.当webpack发现某个文件处理不了的时候,会查找webpack.config.js这个文件

  看module.rules数组中,是否配置了loader

 

  4.webpack把index.css这个文件,先转交给最后一个loader进行处理(先交给css-loader)

  5.当css-loader处理完毕后,会把处理的结果,转交给下一个loader(转交给style-loader)

  6.当style-loader处理完毕之后,发现没有下一个loader了,于是就把处理的结果,转交给              webpack

  7.webpack把style-loader处理的结果,合并到/dist/bundle.js中,最终生成打包好的文件

 

4.打包处理less文件

  1.运行 npm i [email protected] [email protected] -D 命令

  2.在webpack.config.js的module数组中,添加loader规则如下:

module:{//所有第三方文件模块的匹配规则
    rule:{//文件后缀名的匹配规则
        {test:/\.less$/,use:['style-loader',css-loader','less-loader']}
    ]
}

5.打包处理样式表中url路径相关的文件

 

   1.运行 npm i [email protected] [email protected] -D 命令

  2.在webpack.config.js的module->rules数组中,添加loader规则如下:

module:{//所有第三方文件模块的匹配规则
    rules:[//文件后缀的匹配规则
        {test:/\.jpg|png|gift$/,use:'url-loader?limit=22229'},
    ]
}

  其中?之后的是loader的参数项

  limit用来指定图片的大小,单位是字节(byte)

  只有<=limit 大小的图片,才会被转为base64格式图片

6.打包处理js文件中的高级语法

webpack只能打包处理一部分高级的JavaScript语法。对于那些webpack无法处理的高级JS语法,需要借助于babel-loader进行打包处理。例如webpack无法处理下面的JavaScript代码:

//1.定义了名为info的装饰器
function info(target){
    //2.为目标添加静态属性 info
    target.info = 'Person info'
}

//3.为Person类应用info装饰器
@info
class Person{}

//4.打印Person的静态属性 info
console.log(Person.info)

  1.安装babel-loader相关的包

  运行如下命令安装对应的依赖包

  npm i [email protected] @babel/[email protected] @babel/[email protected] -D

  在webpack.config.js的module->rules数组中添加如下规则:

//注意:必须使用exclude指定排除项,因为node_modules目录下的第三方包不需要被打包
{test:/\.js$/,use:babel:loader',exclude:/node_modules/}

 

  2.配置babel-loader

  在根目录下,创建名为babel.config.js的配置文件,定义Babel的配置项如下:

module.exports = {
    //声明 babel 可用的插件
    plugins:[['@bable/plugin-proposal-decorator',{legacy:true}]]
}

 

    

标签:处理,js,webpack,css,loader,打包
From: https://www.cnblogs.com/funkyd/p/16648551.html

相关文章

  • 解决:'webpack-dev-server' 不是内部或外部命令,也不是可运行的程序 或批处理文件 根目
    解决:'webpack-dev-server'不是内部或外部命令,也不是可运行的程序或批处理文件根目录删除node_modules文件夹运行“npmrundev”相信很多人在使用webpack-dev-server......
  • webpack中的插件
    1.webpack插件的作用通过安装和配置第三方插件,可以拓展webpack的能力,从而让webpack用起来更方便。最常用的webpack插件如下有两个:webpack-dev-server类似于node.js......
  • webpack打包
    什么是webpack?本质上,webpack是一个现代JavaScript应用程序的静态模块打包器(modulebundler)。当webpack处理应用程序时,它会递归地构建一个依赖关系图(dependency......
  • How to remove and replace loader arms for JCB 3CX 4CX backhoe loader
    ThisinstructionshowtheguideonhowtoremoveandreplaceloaderarmsforJCB3CX4CXbackhoeloader.MorerepaircaseforJCB,pleasereferto:JCBTroubleR......
  • 初识webpack
    1.什么是webpack?概念:webpack是前端项目工程化的具体解决方案主要功能:它提供了友好的前端模块化开发支持,以及代码压缩混淆、处理浏览器端JavaScript的兼容性(根据配置,来兼......
  • webpack css-loader模块化导致的antd样式不好用解决方案
    css-loader模块化会导致antd样式文件无效,解决的方式就是排除node_modules下的目标文件就可以如果你用的less就可以按以下方式来配置{test:/\.less$/,inclu......
  • webPack安装
    WebPack:全局安装:安装到npm默认的依赖包目录在任意目录执行:npminstall-gwebpack或cnpminstall-gwebpack本地安装:安装指定应用程序目录......
  • 带有getResource()示例的Spring Resource loader
    @AutowiredResourceLoaderresourceLoader;Resourceresource=resourceLoader.getResource("file:c:\\testing.txt");Resourceresource=resourceLoader.getReso......
  • webpack打包分析webpack-bundle-analyzer 打包文件分析工具
    最近需要减少项目打包后的文件(bundle)的大小,那么首先需要了解bundle的构成。目前我已知的方法有两种:利用webpack-bundle-analyzer插件利用webpack官方提供的分析功能......
  • webpack5 中使用iframe 复用导航栏时js代码多次编译问题
    作为webpack萌新,在使用webpack时,偶然发现热更新了多次,最开始以为是配置问题,网上找了很久都没有答案,无意看见一个一个帖子说多引用了一遍js文件,于是我我回去找代码看是不是......