Webpack中l(wèi)oader打包各種文件的方法實(shí)例
前言
使用webpack時(shí),在main.js文件中直接使用如下代碼導(dǎo)入了style.css文件,控制臺(tái)中顯示如下錯(cuò)誤: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中默認(rèn)只能打包.js類型文件,無(wú)法打包其他類型文件。如果要打包非.js類型文件,需要手動(dòng)安裝一些第三方loader加載器。
以下為各種文件類型打包實(shí)例:
處理css文件
方式一
在項(xiàng)目中用npm命令本地安裝style-loader和css-loader兩個(gè)包
npm install style-loader css-loader --save--dev
在引用style.css文件時(shí),將import './css/style.css';代碼改為以下代碼:
import 'style-loader!css-loader!./style.css'")'; //先經(jīng)過(guò)css-loader和style-loader處理
重新用webpack打包
npm run dev
這種方式的缺點(diǎn)是,當(dāng)需要引入多個(gè)css文件,每次引入時(shí)都需要加style-loader!css-loader!,比較麻煩,因此推薦使用以下方式:
方式二
在項(xiàng)目中用npm命令本地安裝style-loader和css-loader兩個(gè)包
npm install style-loader css-loader --save--dev
打開webpack.config.js文件,在里面新增一個(gè)配置節(jié)點(diǎn)module,在module對(duì)象中,有一個(gè)rules屬性,它是一個(gè)數(shù)組,里面存放了所有第三方文件匹配和處理規(guī)則。如下代碼匹配處理css文件:
module: { // 配置所有第三方loader 模塊 rules: [ // 第三方模塊的匹配規(guī)則 { test: /\.css$/, use: ['style-loader', 'css-loader'] }, // 處理 CSS 文件的 loader ] }
注意:此處'style-loader'和'css-loader'順序不可替換。因?yàn)閡se中處理順序?yàn)閺暮笸?。先用css-loader對(duì)css文件進(jìn)行處理,將處理后的結(jié)果交給style-loader作進(jìn)一步處理,處理為webpack可以進(jìn)行打包的數(shù)據(jù)。
引入style.css文件
import './css/style.css';
重新用webpack打包
npm run dev
以下所有其他類型文件的打包同方式二
處理less文件
在項(xiàng)目中用npm命令本地安裝style-loader和css-loader和less-loader和less三個(gè)包(若已有style-loader和css-loader則不必再安裝這兩個(gè))
npm install style-loader css-loader less-loader less --save--dev
打開webpack.config.js文件,在節(jié)點(diǎn)module中rules屬性數(shù)組中,新增如下less的規(guī)則:
{ test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] } // 處理 less 文件的 loader
引入style.less文件
import './css/style.less';
重新用webpack打包
npm run dev
處理scss文件
在項(xiàng)目中用npm命令本地安裝style-loader和css-loader和sass-loader和node-sass四個(gè)包(若已有style-loader和css-loader則不必再安裝這兩個(gè))
npm install style-loader css-loader sass-loader node-sass --save--dev
打開webpack.config.js文件,在節(jié)點(diǎn)module中rules屬性數(shù)組中,新增如下scss的規(guī)則:
{ 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默認(rèn)無(wú)法處理url,因此也需要手動(dòng)安裝第三方loader
在項(xiàng)目中用npm命令本地安裝url-loader和file-loader兩個(gè)包
npm install url-loader file-loader --save--dev
打開webpack.config.js文件,在節(jié)點(diǎn)module中rules屬性數(shù)組中,新增如下的規(guī)則:
{ 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高級(jí)語(yǔ)法
webpack默認(rèn)只能處理一部分的ES6語(yǔ)法,對(duì)于一些更高級(jí)的ES6語(yǔ)法,webpack無(wú)法處理,如下代碼用webpack打包會(huì)報(bào)錯(cuò)。
class Person { static info = {name:'zlx',age:18} }; console.log(Person.info);
webpack需要借助于第三方的 loader,這里使用Babel,將高級(jí)的ES6語(yǔ)法轉(zhuǎn)為低級(jí)的語(yǔ)法之后,再將結(jié)果進(jìn)行打包。
用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文件,在節(jié)點(diǎn)module中rules屬性數(shù)組中,新增如下的規(guī)則:
{ test: /\.js$/, use: 'babel-loader', exclude: /node_modules/ }, // exclude是防止node_modules中的js文件被打包
在項(xiàng)目的 根目錄中,新建一個(gè) 叫做 .babelrc 的Babel 配置文件,這個(gè)配置文件,屬于JSON格式。里面寫入如下代碼:
{ "presets": ["env", "stage-0"], "plugins": ["transform-runtime"] }
重新用webpack打包
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
JavaScript學(xué)習(xí)筆記之獲取當(dāng)前目錄的實(shí)現(xiàn)代碼
用來(lái)獲取當(dāng)前目錄的js代碼,需要的朋友可以參考下,主要利用了split函數(shù)。2010-12-12js判斷瀏覽器類型及設(shè)備(移動(dòng)頁(yè)面開發(fā))
這篇文章主要介紹了js判斷瀏覽器類型及設(shè)備(移動(dòng)頁(yè)面開發(fā)),需要的朋友可以參考下2015-07-07一個(gè)用javascript寫的select支持上下鍵、首字母篩選以及回車取值的功能
一個(gè)用javascript寫的select支持上下鍵、首字母篩選以及回車取值的功能2009-09-09微信公眾號(hào)網(wǎng)頁(yè)分享功能開發(fā)的示例代碼
這篇文章主要介紹了微信公眾號(hào)網(wǎng)頁(yè)分享功能開發(fā)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05JS實(shí)現(xiàn)的新浪微博大廳文字內(nèi)容滾動(dòng)效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)的新浪微博大廳文字內(nèi)容滾動(dòng)效果代碼,可實(shí)現(xiàn)頁(yè)面圖文元素定時(shí)滾動(dòng)的效果,涉及JavaScript時(shí)間函數(shù)定時(shí)改變頁(yè)面元素的相關(guān)技巧,需要的朋友可以參考下2015-11-11利用10行js代碼實(shí)現(xiàn)上下滾動(dòng)公告效果
這篇文章主要給大家介紹了關(guān)于利用10行js代碼實(shí)現(xiàn)滾動(dòng)公告效果的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起看看吧。2017-12-12使用JavaScript修改瀏覽器URL地址欄的實(shí)現(xiàn)代碼
這篇文章主要介紹了如何使用JavaScript修改瀏覽器URL地址欄,需要的朋友可以參考下2013-10-10JS實(shí)現(xiàn)的網(wǎng)頁(yè)倒計(jì)時(shí)數(shù)字時(shí)鐘效果
這篇文章主要介紹了JS實(shí)現(xiàn)的網(wǎng)頁(yè)倒計(jì)時(shí)數(shù)字時(shí)鐘效果,是一款非常實(shí)用的javascript倒計(jì)時(shí)特效,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03js實(shí)現(xiàn)兼容性好的微軟官網(wǎng)導(dǎo)航下拉菜單效果
這篇文章主要介紹了js實(shí)現(xiàn)兼容性好的微軟官網(wǎng)導(dǎo)航下拉菜單效果,涉及JavaScript基于鼠標(biāo)事件實(shí)現(xiàn)頁(yè)面樣式變換的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-09-09