這篇文章主要為大家展示了“react.js如何使用webpack搭配環(huán)境”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“react.js如何使用webpack搭配環(huán)境”這篇文章吧。
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),嘉定企業(yè)網(wǎng)站建設(shè),嘉定品牌網(wǎng)站建設(shè),網(wǎng)站定制,嘉定網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,嘉定網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
如果你想直接上手開發(fā),而跳過這些搭配環(huán)境的繁瑣過程,推薦你使用官方的create-react-app命令
npm install -g create-react-app //安裝create-react-app腳手架 npm為node.js的包管理工具,請確保你已經(jīng)安裝了node.js create-react-app my-app //使用create-react-app創(chuàng)建,my-app為項(xiàng)目名稱 cd my-app/ //進(jìn)入my-app目錄 npm start //運(yùn)行項(xiàng)目
現(xiàn)在打開 http://localhost:3000/ 就能看到初始界面
我不大愿意使用官方自帶這個腳手架,是因?yàn)樗膚ebpack配置太復(fù)雜,我比較愚鈍看不大懂,還望有大神能研究透徹分享一下。
要如何create-react-app內(nèi)部的webpack配置文件解壓出來?
npm run eject
源代碼
每次看教程我都喜歡先把項(xiàng)目跑起來,然后再一句一句代碼地去了解。如果你也是:
git clone https://github.com/lingjiawen/HelloReact.git cd HelloReact/ npm install npm run dev
一、創(chuàng)建項(xiàng)目結(jié)構(gòu)
新建一個文件夾,命名為HelloReact
順口提一下,我用的IDE是Sublime
在該文件夾內(nèi)這樣組織你的項(xiàng)目結(jié)構(gòu):
|--app //項(xiàng)目組件 |--components //組件結(jié)構(gòu) |---Hello.jsx |--main.js //入口文件 |--build //項(xiàng)目build文件 |--index.html //索引html |--.babelrc //babel轉(zhuǎn)碼工具配置文件 |--package.json //npm說明文件,可以理解為包管理文件 |--webpack.config.js //webpack配置文件
在build/index.html中拷貝以下代碼:
ReactDemo1
React代碼插入到main中,而bundle.js是webpack打包生成的js文件,在這里你可以先幫它記下來下文看到了再回來一看就清楚了。
在package.json中輸入以下代碼:
注意,所有的注釋都不要輸入進(jìn)去!
//package.json { "name": "HelloReact", //項(xiàng)目名字 "version": "1.0.0", //項(xiàng)目版本 "main": "webpack.config.js", "scripts": { "start": "webpack", //npm start的配置 }, "author": "", //作者 "license": "ISC", "devDependencies": { //調(diào)試依賴項(xiàng) "babel-core": "^6.25.0", "babel-loader": "^7.1.1", "babel-plugin-react-transform": "^2.0.2", "babel-preset-es2015": "^6.24.1", "babel-preset-react": "^6.24.1", "react": "^15.6.1", "react-dom": "^15.6.1", "react-transform-hmr": "^1.0.4", "webpack": "^3.4.1", }, "description": "", "dependencies": { //項(xiàng)目依賴項(xiàng) } }
在webpack配置文件webpack.config.js中輸入以下代碼:
var webpack = require('webpack');//引入Webpack模塊,注意這里只能使用ES5語法引入 module.exports = { entry: __dirname + "/app/main.js",//唯一入口文件 output: { path: __dirname + "/build",//打包后的bundle.js文件存放的地方 filename: "bundle.js" //打包后的文件名 }, module: { //loaders加載器 loaders: [ { test: /\.(js|jsx)$/, //匹配loaders所處理的文件的擴(kuò)展名的正則,如jsx和js文件 loader: 'babel-loader' //loader的名稱 } ] }, plugins: [ new webpack.HotModuleReplacementPlugin()//熱模塊替換插件 ] };
.babelrc是babel轉(zhuǎn)碼器的配置文件,它能將es6代碼轉(zhuǎn)換成es5代碼,還支持react語法轉(zhuǎn)換
在.babelrc中輸入以下代碼:
//.babelrc { "presets": [ "react", "es2015" ], "env": { "development": { "plugins": [ [ "react-transform", { "transforms": [ { "transform": "react-transform-hmr", "imports": [ "react" ], "locals": [ "module" ] } ] } ] ] } } }
在app/components/Hello.jsx中輸入以下代碼:
import React from 'react'; //引入react //創(chuàng)建組件類:名字首字母必須大寫 class Hello extends React.Component { render() { return (Hello World!) } } //導(dǎo)出組件 export default Hello;
React 使用 JSX 來替代常規(guī)的 JavaScript。
JSX 是一個看起來很像 XML 的 JavaScript 語法擴(kuò)展。
它看起來是在Javascript代碼里直接寫XML的語法,而實(shí)質(zhì)上是一個語法糖,每一個XML標(biāo)簽都會被JSX轉(zhuǎn)換工具(如babel)轉(zhuǎn)換成純Javascript代碼
在app/main.js中輸入以下代碼:
//main.js import React from 'react'; import ReactDOM from 'react-dom'; import Hello from './components/Hello.jsx'; ReactDOM.render(, document.getElementById('main') );
二、運(yùn)行項(xiàng)目
打開命令行,cd到HelloReact文件夾目錄,運(yùn)行
npm install
該命令會安裝package.json的所有依賴文件,安裝完成后,運(yùn)行:
npm start
npm start命令是剛才你在package.json中定義的:
"scripts": { "start": "webpack", }
注:只有start可以省略run,其他都需要加上run,如 npm run dev;
你會發(fā)現(xiàn)build.js中多了bundle.js文件,這是你在webpack.config.js中定義的打包文件:
var webpack = require('webpack');//引入Webpack模塊,注意這里只能使用ES5語法引入 module.exports = { …… output: { path: __dirname + "/build",//打包后的bundle.js文件存放的地方 filename: "bundle.js" //打包后的文件名 }, …… };
打開該目錄下的index.html,看到以下輸出運(yùn)行成功:
三、添加熱替換模塊
項(xiàng)目已經(jīng)可以運(yùn)行了,但是每次輸完代碼都要npm start進(jìn)行打包,想想都沒辦法忍受,這就需要用到webpack-dev-server熱替換模塊,所見即所得
其實(shí)在前面的代碼中,為了避免麻煩,我已經(jīng)偷偷將熱替換模塊的部分配置加了進(jìn)去
webpack.config.js中的
…… plugins: [ new webpack.HotModuleReplacementPlugin()//熱模塊替換插件 ] ……
package.json中的
"devDependencies": { …… "babel-plugin-react-transform": "^2.0.2", "react-transform-hmr": "^1.0.4", "webpack-dev-server": "^2.6.1" …… }
還有.babelrc中的
"env": { "development": { "plugins": [ [ "react-transform", { "transforms": [ { "transform": "react-transform-hmr", "imports": [ "react" ], "locals": [ "module" ] } ] } ] ] } }
你可以將這些代碼刪除,發(fā)現(xiàn)也是可以正常打包并運(yùn)行。因?yàn)橹安]有用到熱加載
那我現(xiàn)在想用,要怎么用呢?
很簡單,在package.json中加入:
…… "scripts": { "start": "webpack", "dev": "webpack-dev-server" } ……
好,現(xiàn)在運(yùn)行一下npm run dev
打開localhost:8080
咦,怎么是列出文件列表,哦哦哦,原來是沒有配置默認(rèn)路徑;
…… "scripts": { "start": "webpack", "dev": "webpack-dev-server --contentBase='./build' " } ……
重新運(yùn)行npm run dev:
修改app/components/Hello.jsx
保存后再回到頁面,發(fā)現(xiàn)頁面已經(jīng)自動更新:
以上是“react.js如何使用webpack搭配環(huán)境”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!