快速搭建React的環(huán)境步驟詳解
前端生態(tài)這幾年可謂迎來(lái)了大發(fā)展,在這個(gè)生態(tài)圈內(nèi),不接受新事物學(xué)習(xí)新技能,等于墮入魔道。
本文嘗試對(duì)前端開(kāi)發(fā)利器React,以及構(gòu)建項(xiàng)目過(guò)程中涉及的技術(shù)棧進(jìn)行介紹,以期開(kāi)啟整個(gè)構(gòu)建流程上的思考。
有必要指出的是,要弄明白一件事情的原理,首先要知道它的目的是什么。
1、Nodejs & NPM
為什么要提nodejs呢?
與其說(shuō)nodejs提供了服務(wù)端開(kāi)發(fā)的另一種可能,不如說(shuō)它徹底改變了整個(gè)前端開(kāi)發(fā)的生態(tài)。nodejs平臺(tái)上衍生出了強(qiáng)大的npm、grunt、express等,幾乎重新定義了前端的工作流程和開(kāi)發(fā)方式。
這里有必要來(lái)講一講NPM(node package manager)這個(gè)包管理器。
npm是javascript包管理器,我們可以在npm上找到、分享和使用來(lái)自無(wú)數(shù)開(kāi)發(fā)者貢獻(xiàn)的代碼包,而無(wú)需自己造輪子。
使用npm,需要安裝node。新的版本的nodejs已經(jīng)集成了npm,安裝好nodejs,通過(guò)以下命令查看所安裝的版本:
$ npm -v
在項(xiàng)目目錄內(nèi),當(dāng)在命令行執(zhí)行
$ npm install
它會(huì)識(shí)別一個(gè)叫package.json的文件,并嘗試安裝該文件內(nèi)配置的依賴(lài)包。
2、React
React的組建化思想使得代碼重用性高,易于測(cè)試、更容易分離關(guān)注點(diǎn)(separation of concerns)。
React還宣稱(chēng)Learn Once, Write Anywhere。既可運(yùn)行在客戶(hù)端瀏覽器,又能在服務(wù)端渲染,同時(shí)React Native還使得React開(kāi)發(fā)原生app成為可能。
下面我們來(lái)寫(xiě)一個(gè)簡(jiǎn)單的React程序,讓其能夠運(yùn)行起來(lái):
項(xiàng)目目錄:
第一步:新建一個(gè)package.json文件,指定項(xiàng)目所需的依賴(lài)包。
{ "name": "react-tutorials", "version": "1.0.0", "description": "", "author": "yunmo", "scripts": { "start": "webpack-dev-server --hot --progress --colors --host 0.0.0.0", "build": "webpack --progress --colors --minimize" }, "dependencies": { "react": "^15.4.0", "react-dom": "^15.4.0" }, "devDependencies": { "webpack": "^2.2.1", "webpack-dev-server": "^2.4.2" }, "license": "" }
這是npm包管理器的必要文件,定義了該項(xiàng)目的名稱(chēng)、版本、啟動(dòng)命令、生產(chǎn)環(huán)境依賴(lài)包(dependencies)和開(kāi)發(fā)環(huán)境依賴(lài)包(devDependencies)。
第二步:新建一個(gè)index.html文件。
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>yunmo</title> <meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"/> </head> <body> <div id="yunmo"></div> <script src="bundle.js"></script> </body> </html>
第三步:寫(xiě)一段簡(jiǎn)單的React代碼。
var React = require('react'); var ReactDOM = require('react-dom'); var element = React.createElement( 'h1', {className: 'yunmo'}, '云陌,歡迎來(lái)到react的世界!' ); ReactDOM.render ( element, document.getElementById('yunmo') );
第四步:運(yùn)行。
那么如何在瀏覽器里運(yùn)行呢?這里我們需要借助強(qiáng)大的webpack-dev-server來(lái)開(kāi)啟本地服務(wù)器。
我們可以看到上面的package.json里面有webpack和webpack-dev-server依賴(lài)包。下面會(huì)介紹webpack。
當(dāng)然我們還可以通過(guò)nodejs來(lái)建立一個(gè)本地服務(wù)器,但這里其實(shí)webpack-dev-server是一個(gè)小型的nodejs Express服務(wù)器,它使用webpack-dev-middleware中間件來(lái)服務(wù)于webpack包。
webpack.config.js文件配置如下:
var webpack = require('webpack'); module.exports = { entry: ['./app/main.js'], output: { path: __dirname + '/build', filename: 'bundle.js' }, module: { loaders: [] } }
這樣我們?cè)诿钚型ㄟ^(guò)npm install安裝好依賴(lài)包以后,敲打命令
$ npm start
運(yùn)行服務(wù)后,在瀏覽器中輸入http://localhost:8080/
React在瀏覽器運(yùn)行結(jié)果
一個(gè)簡(jiǎn)單的React項(xiàng)目便運(yùn)行起來(lái)了。
3、Webpack
webpack是一款現(xiàn)代JavaScript應(yīng)用的模塊加載兼打包工具,它不僅僅可以打包JavaScript,還可以打包styles,images等資源。
來(lái)看一個(gè)典型的webpack配置:
var webpack = require('webpack'); var path = require('path') module.exports = { entry: ['./app/main.js'], output: { path: path.resolve(__dirname, '/build'), filename: 'bundle.js' }, module: { loaders: [ { test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader' }, { test: /\.scss$/, loaders: ["style-loader", "css-loader", "sass-loader"] }, { test: /\.(otf|eot|svg|ttf|woff|png|jpg)/, loader: 'url-loader?limit=8192&name=images/[hash:8].[name].[ext]' } ] }, plugins: [ new webpack.optimize.UglifyJsPlugin() ] }
從上面webpack配置里面可以看出來(lái)有一些基本的配置點(diǎn),也反映了webpack的四個(gè)理念:
- entry——webpack會(huì)根據(jù)應(yīng)用的依賴(lài)關(guān)系,創(chuàng)建一個(gè)關(guān)系表。該表的起始點(diǎn)便是所謂的entry point(入口點(diǎn))。entry point會(huì)告訴webpack從哪入手,webpack會(huì)以該表的依賴(lài)關(guān)系作為打包依據(jù)。
- output——用于配置打包后的文件放置路徑。
- loader——webpack把每個(gè)文件都看作組建(如.css, .html, .scss, .jpg, .png等),但是webpack只能識(shí)別JavaScript。這時(shí)候loaders便可以把這些文件轉(zhuǎn)換成組建,進(jìn)而被添加到依賴(lài)關(guān)系表。
- plugins——因?yàn)閘oaders作用方式是以單一文件為基礎(chǔ)的,所以plugins更廣泛的用來(lái)對(duì)打包組建形成的集合(compilations)進(jìn)行自定義操作。
這樣,一個(gè)完整的模塊打包體系就建立起來(lái)了。
4、ES6
ES6,即ECMAScript 6.0,是 JavaScript的下一代標(biāo)準(zhǔn)。ES6里面新增了很多語(yǔ)法特性,使得編寫(xiě)復(fù)雜的應(yīng)用更加優(yōu)雅自然。
ES6中引入了諸如let和const、箭頭函數(shù)、解構(gòu)賦值、字符串模版、Module、Class、Promise等特性,使得前后端編程語(yǔ)言在語(yǔ)法形式上的差異越來(lái)越小。
我們來(lái)看一下:
import React from 'react' //模塊引入 import '../styles/reactStack.scss' class ReactStack extends React.Component { //class特性 render() { const learner = {name: '云陌', age: 18} //const定義變量 const mainSkills = ['React', 'ES6', 'Webpack', 'Babel', 'NPM',] const extraSkills = ['Git', 'Postman'] const skillSet = [...mainSkills, ...extraSkills] const { name } = learner //解構(gòu)賦值 let greetings = null //let定義變量 if (name) { greetings = `${name},歡迎來(lái)到${mainSkills[0]}的世界!` //字符模版 } //以下用了箭頭函數(shù) return ( <div className="skills"> <div>{greetings}</div> <ol> {skillSet.map((stack, i) => <li key={i}>{stack}</li>)} </ol> </div> ) } } export default ReactStack //模塊導(dǎo)出
當(dāng)然,并非所有瀏覽器都能兼容ES6全部特性,但看到這么優(yōu)雅的書(shū)寫(xiě)方式,只能看怎么行呢?因此,這里又引出了一個(gè)神器,Babel!
5、Babel
Babel是一款JavaScript編譯器。
Babel可以將ES6語(yǔ)法的代碼轉(zhuǎn)碼成ES5代碼,從而在瀏覽器環(huán)境中實(shí)現(xiàn)兼容。
Babel內(nèi)置了對(duì)JSX的支持,所以我們才能向上面那樣直接return一個(gè)JSX形式的代碼片段。
具體用法不在本文過(guò)多講述。
6、Styles引入
在上面的代碼中,有以下樣式引入方式:
import '../styles/reactStack.scss'
樣式文件如下:
body { background: #f1f1f1; } .skills { h3 { color: darkblue; } ol { margin-left: -20px; li { font-size: 20px; color: rgba(0, 0, 0, .7); &:first-child { color: #4b8bf5; } } } }
樣式文件要在項(xiàng)目中起作用,還需要在package.json里面添加相應(yīng)的loader依賴(lài),如css-loader, sass-loader, style-loader等,別忘了package.json里還需要node-sass依賴(lài),然后安裝即可。
webpack.config.js中相應(yīng)配置如下:
module: { loaders: [ { test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader' }, { test: /\.scss$/, loaders: ["style-loader", "css-loader", "sass-loader"] } ] }
再將main.js中的內(nèi)容作如下更改:
import React from 'react' import ReactDOM from 'react-dom' import ReactStack from './pages/ReactStack' ReactDOM.render ( <ReactStack />, document.getElementById('yunmo') );
最后在瀏覽器中可以看到:
結(jié)語(yǔ)
至此,一個(gè)簡(jiǎn)單的React項(xiàng)目便搭建起來(lái)了。
在后續(xù)的文章中,我將對(duì)本文涉及到的React技術(shù)棧做專(zhuān)門(mén)的講解,不僅限于硬性技能。當(dāng)然更多的是實(shí)踐做法上的總結(jié),因?yàn)槿绻莆账鼈兊睦碚?,?xì)看官方文檔和源碼是最好不過(guò)的做法。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ReactNative?狀態(tài)管理redux使用詳解
這篇文章主要介紹了ReactNative?狀態(tài)管理redux使用詳解2023-03-03如何去除富文本中的html標(biāo)簽及vue、react、微信小程序中的過(guò)濾器
這篇文章主要介紹了如何去除富文本中的html標(biāo)簽及vue、react、微信小程序中的過(guò)濾器,在vue及react中經(jīng)常會(huì)遇到,今天通過(guò)實(shí)例代碼給大家講解,需要的朋友可以參考下2018-11-11react-pdf?打造在線(xiàn)簡(jiǎn)歷生成器的示例代碼
本文主要介紹了react-pdf?打造在線(xiàn)簡(jiǎn)歷生成器的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02解析React中useMemo與useCallback的區(qū)別
這篇文章主要介紹了React中useMemo與useCallback的區(qū)別,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08react setupProxy.js導(dǎo)致項(xiàng)目無(wú)法啟動(dòng)的解決
這篇文章主要介紹了react setupProxy.js導(dǎo)致項(xiàng)目無(wú)法啟動(dòng)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07