成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React實(shí)踐(一)——webpack4搭建開發(fā)環(huán)境

Simon / 471人閱讀

摘要:按需引入在入口文件中引入全局的如果僅僅是這樣的話,我們加載組件是全部加載的,這時(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
配置eslint

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/ },
配置stylelint

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、按需引入antd

cnpm 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

相關(guān)文章

  • 關(guān)于Vue2些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    sutaking 評論0 收藏0
  • 關(guān)于Vue2些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    khs1994 評論0 收藏0
  • webpack4詳細(xì)教程,從無到有搭建react腳手架(

    摘要:是一個(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...

    zhkai 評論0 收藏0
  • webpack 基礎(chǔ)與項(xiàng)目優(yōu)化實(shí)踐總結(jié)

    摘要:前言本文基于,主要涉及基本概念基本配置和實(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)行...

    Scorpion 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<