Loader和Plugin的不同?

x33g5p2x  于2022-04-16 转载在 其他  
字(1.1k)|赞(0)|评价(0)|浏览(288)

一、写在前面
之前面试官就问道loader和plugin有什么不同?当时只是根据自己脑子里面想的进行回答,所以今天就总结一下两者的区别。
二、具体总结
loader:loader从字面的意思理解,是加载的意思。由于webpack 本身只能打包js文件,所以,针对css,图片等格式的文件没法打包,就需要引入第三方的模块进行打包。loader虽然是扩展了 webpack ,但是它只专注于转化文件(transform)这一个领域,完成压缩,打包,语言翻译。loader是运行在NodeJS中。仅仅只是为了打包,仅仅只是为了打包,仅仅只是为了打包,重要的话说三遍!
如:css-loader和style-loader模块是为了打包css的
babel-loader和babel-core模块时为了把ES6的代码转成ES5
url-loader和file-loader是把图片进行打包的。
plugin: plugin也是为了扩展webpack的功能,但是 plugin 是作用于webpack本身上的。而且plugin不仅只局限在打包,资源的加载上,它的功能要更加丰富。从打包优化和压缩,到重新定义环境变量,功能强大到可以用来处理各种各样的任务。webpack提供了很多开箱即用的插件:CommonChunkPlugin主要用于提取第三方库和公共模块,避免首屏加载的bundle文件,或者按需加载的bundle文件体积过大,导致加载时间过长,是一把优化的利器。而在多页面应用中,更是能够为每个页面间的应用程序共享代码创建bundle。
插件可以携带参数,所以在plugins属性传入new实例。
针对html文件打包和拷贝(还有很多设置)的插件:html-webpack-plugin。 不但完成了html文件的拷贝,打包,还给html中自动增加了引入打包后的js文件的代码(),还能指明把js文件引入到html文件的底部等等。
代码如下所示:

plugins:[   
//对html模板进行处理,生成对应的html,引入需要的资源模块
new HtmlWebpackPlugin({
    template:'./index.html',//模板文件,即需要打包和拷贝到build目录下的html文件
    filename:'index.html',//目标html文件
    chunks:['useperson'],//对应加载的资源,即html文件需要引入的js模块
    inject:true//资源加入到底部,把模块引入到html文件的底部
    })
]

创作挑战赛

新人创作奖励来咯,坚持创作打卡瓜分现金大奖

相关文章