摘要:按需引入在入口文件中引入全局的如果僅僅是這樣的話,我們加載組件是全部加載的,這時(shí)候我們要在的中配置這樣之后就可以按照的官網(wǎng)來使用里的組件了。啦,這樣一個(gè)簡單的開發(fā)環(huán)境就搭建好了。
github
1、創(chuàng)建基本目錄結(jié)構(gòu)npm init
創(chuàng)建src文件夾,再其中新建index.html
安裝webpack依賴:
npm install webpack webpack-cli webpack-dev-server --save-dev
配置webpack,根目錄下新建webpack.config.js:
module.exports = { mode: "development" // 生產(chǎn)環(huán)境為"production" }
配置命令行:
// package.json { ... "script": { ... "start": "webpack-dev-serve --hot" } }
利用html-webpack-plugin插件配置自動(dòng)生成頁面和注入打包后的js
npm install html-webpack-plugin --save-dev
webpack.config.js中配置:
const path = require("path") const HtmlWebpackPlugin = require("html-webpack-plugin") // 創(chuàng)建插件示例對象 const htmlPlugin = new HtmlWebpackPlugin({ template: path.join(__dirname, "./src/index.html"), filename: "index.html" }) module.exports = { mode: "development", plugins: [ htmlPlugin ] }2、搭建react開發(fā)環(huán)境 2.1、react配置
npm install react react-dom --save
使用babel轉(zhuǎn)譯jsx語法(一定要注意版本):
npm install babel-core babel-loader@7 babel-plugin-transform-runtime --save-dev
npm install babel-preset-env babel-preset-stage-0 babel-preset-react --save-dev
配置babel
// webpack.config.js module.exports = { ... modules: { rules: [ { test: /.js|jsx$/, use: "babel-loader", exclude: /node_modules/ } // 一定要添加exclude排除項(xiàng) ] }, resolve: { extensions: ["js", "jsx", "json"] // 配置導(dǎo)入模塊的后綴名忽略 alias: { "@": path.join(__dirname, "/src") // 配置src路徑標(biāo)識(shí)符 } } }
根目錄新建 .babelrc
{ "presets": ["env", "stage-0", "react"], "plugins": ["transform-runtime"] }2.2 配置sass-loader, css-loader以及其他loader:
cnpm install style-loader css-loader --save-dev
cnpm install sass-loader node-sass -save-dev
cnpm install url-loader file-loader --save-dev
注意在css-loader之后是可以加參數(shù)的,格式類似url的query格式:
modules: 開啟模塊化(只針對類名和id,標(biāo)簽選擇器依然是全局)
localIdentName:
2.1 [path]: 相對于src的路徑
2.2 [name]: 樣式文件名
2.3 [local]: 樣式原名
2.4 [hash:8]: 哈希值,8位限制長度
這里我們需要注意的是,我們有可能會(huì)用到第三方的樣式表,而這時(shí)候如果是針對.css文件進(jìn)行模塊化的化,那就用不了了。所以,自己寫的樣式用sass,進(jìn)行模塊化處理,而全局或者第三方樣式表用css。
// webpack.config.js { ... modules: { rules: [ // 一定要添加exclude排除項(xiàng) { test: /.js|jsx$/, use: "babel-loader", exclude: /node_modules/ }, { test: /.css$/, use: ["style-loader", "css-loader"]}, // 字體文件打包處理配置 { test: /.ttf|woff|woff2|eot|svg$/, use: "url-loader"}, // 打包處理scss并模塊化(只針對類名或id,標(biāo)簽選擇器不會(huì)模塊化) { test: /.scss$/, use: ["style-loader", "css-loader?modules&localIdentName=[local]-[hash:8]", "sass-loader"]} ] }, }2.3 配置eslint、stylelint
cnpm install eslint eslint-loader --save-dev
項(xiàng)目根目錄新建.eslintrc.js:
module.exports = { "env": { "browser": true, "node": true }, "parserOptions": { "ecmaVersion": 6, "sourceType": "module", "ecmaFeatures": { "jsx": true } }, "rules": { // 允許開發(fā)環(huán)境使用debugger "no-debugger": process.env.NODE_ENV === "production" ? "error" : "off", //禁止使用var "no-var": 2, // 強(qiáng)制操作符周圍有空格 "space-infix-ops": 2, // 語句塊之前的空格(大括號之前有空格) "space-before-blocks": [2, "always"], // 強(qiáng)制在花括號中使用一致的空格 "object-curly-spacing": [2, "always"], // 逗號之后必須有空格 "comma-spacing": [2, { "before": false, "after": true }], // 對象字面量的鍵值之間的冒號后只有一個(gè)空格 "key-spacing": [2, {"mode": "strict"}], // 約定以駝峰法命名 "camelcase": [2, {"properties": "always"}] } }
rules里的規(guī)則可與eslint官網(wǎng)自由配置,也可以用第三方配置好的插件。
webpack.config.js中的loader中配置:
{ enforce: "pre", test: /.js|jsx$/, use: "eslint-loader", exclude: /node_modules/ },
cnpm install stylelint stylelint-webpack-plugin --save-dev
項(xiàng)目根目錄新建stylelint.config.js
module.exports = { defaultServerity: "warning", rules: { // 禁止使用important "declaration-no-important": true, // 選擇器后的大括號前必須有一個(gè)空格 "block-opening-brace-space-before": "always", // url需要加引號 "function-url-quotes": "always", // 禁止空塊 "block-no-empty": true, // 取消小于1的小數(shù)的前導(dǎo)0 "number-leading-zero": "never", // 禁止小數(shù)后的尾隨0 "number-no-trailing-zeros": true, // 函數(shù)逗號之后必須跟空格 "function-comma-space-after": "always", // 函數(shù)逗號前不能加空格 "function-comma-space-before": "never", // 聲明的冒號后必須跟空格 "declaration-colon-space-after": "always", // 聲明的冒號前禁止空格 "declaration-colon-space-before": "never", // 規(guī)定css類名格式(此處為短橫線命名法,例如:.m-title) "selector-class-pattern": "^([a-z][a-z0-9]*)(-[a-z0-9]+)*$" } }
同樣的道理,規(guī)則可以去stylelint官網(wǎng)配置。
webpack.config.js配置:
const StylelintWebpackPlugin = require("stylelint-webpack-plugin") // 創(chuàng)建stylelint插件示例對象 const stylelintPlugin = new StylelintWebpackPlugin({ files: ["src/**/*.s?(a|c)ss"] })
再在plugin中添加就行了。
3、按需引入antdcnpm install antd --save
cnpm install babel-plugin-import --save-dev
在入口文件中引入全局的css:
import "antd/dist/antd.css"
如果僅僅是這樣的話,我們加載react組件是全部加載的,這時(shí)候我們要在.babelrc的plugins中配置:
plugins: [["import", { "libraryName": "antd", "style": "css" }]]
這樣之后就可以按照antd的官網(wǎng)來使用antd里的組件了。
OK啦,這樣一個(gè)簡單的react開發(fā)環(huán)境就搭建好了。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98893.html
摘要:五六月份推薦集合查看最新的請點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...
摘要:五六月份推薦集合查看最新的請點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...
摘要:是一個(gè)現(xiàn)代應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個(gè)前端工程師切圖仔,非常有必要學(xué)習(xí)。官網(wǎng)的文檔非常的棒,中文文檔也非常給力,可以媲美的文檔。建議先看概念篇章,再看指南,然后看和配置總覽。 webpack 是一個(gè)現(xiàn)代 JavaScript 應(yīng)用程序的靜態(tài)模塊打包器,前端模塊化的基礎(chǔ)。作為一個(gè)前端工程師(切圖仔),非常有必要學(xué)習(xí)。 showImg(https://segment...
摘要:前言本文基于,主要涉及基本概念基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行優(yōu)化配置。同一文件中,修改某個(gè)影響其他。 前言:本文基于weboack4.x,主要涉及webpack4 基本概念、基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行...
閱讀 2506·2021-09-28 09:36
閱讀 1508·2021-09-22 15:33
閱讀 3646·2019-08-30 15:44
閱讀 1754·2019-08-29 13:14
閱讀 3141·2019-08-29 11:17
閱讀 1455·2019-08-29 11:03
閱讀 2916·2019-08-26 17:10
閱讀 691·2019-08-26 12:13