国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Webpack中loader打包各種文件的方法實例

來源:懂視網 責編:小采 時間:2020-11-27 21:51:30
文檔

Webpack中loader打包各種文件的方法實例

Webpack中loader打包各種文件的方法實例:前言 使用webpack時,在main.js文件中直接使用如下代碼導入了style.css文件,控制臺中顯示如下錯誤:You may need an appropriate loader to handle this file type, currently no loaders are configured to pro
推薦度:
導讀Webpack中loader打包各種文件的方法實例:前言 使用webpack時,在main.js文件中直接使用如下代碼導入了style.css文件,控制臺中顯示如下錯誤:You may need an appropriate loader to handle this file type, currently no loaders are configured to pro

前言

使用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打包

總結

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Webpack中loader打包各種文件的方法實例

Webpack中loader打包各種文件的方法實例:前言 使用webpack時,在main.js文件中直接使用如下代碼導入了style.css文件,控制臺中顯示如下錯誤:You may need an appropriate loader to handle this file type, currently no loaders are configured to pro
推薦度:
標簽: 文件 方法 打包
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人精品免费视频大全五级 | 国产欧美日韩一区 | 欧美三页 | 国产未成女年一区二区 | 欧美午夜网 | 欧美xx在线 | 国产一区二区网站 | 日本一区二区三区精品视频 | 日本色图在线观看 | 国精品日韩欧美一区二区三区 | 国产精品最新 | 亚洲国产欧美自拍 | 99久久精品免费 | 久操视频免费在线观看 | 久久亚洲欧美综合激情一区 | 欧美第四页 | 国产福利一区二区三区在线观看 | 日韩美一区二区 | 国产一在线| 日本特级淫片免费 | 国产在线精品99一卡2卡 | 日韩精品第一页 | 中文字幕第七页 | 精品成人一区二区三区免费视频 | 欧美第1页| 国产一区二区久久久 | 国产成人精品日本亚洲11 | 日韩在线一区二区三区 | 国产第4页 | 激情综合网站 | 一区二区三区高清不卡 | 国产三级在线免费 | 国产精品免费看久久久麻豆 | 一级毛片子| 国产精品人成人免费国产 | 黄动漫3d无遮挡免费观看 | 国产高清视频免费在线观看 | 美女视频黄a视频全免费应用 | 一区二区视频在线播放 | 久久精品a国产一级 | 日韩a在线观看免费观看 |