react+webpack+react-router+redux项目搭建(二)

(6)react

a. >npm install --save react react-dom
使用react修改上述src/index.js的内容


import React from 'react';

import ReactDom from 'react-dom';

ReactDom.render(

 <div>React使用成功</div>, document.getElementById('app'));

运行命令:npm run build ,再打开浏览器查看效果

a. react组件化

为了体现组件化,将“React使用成功”放到Display组件里


import React, {Component} from 'react';

export default class Dispaly extends Component {

render() {

 return{

 <div>React安装成功</div>

 }

}

}

同时修改src/index.js的内容


import React from 'react';

import ReactDom from 'react-dom';

+ import Display from './component/Display/Display'

+ ReactDom.render(

 <Display/>, document.getElementById('app'));

b. react-router

安装

npm install --save react-router-dom

新建router文件夹和组件

** >cd src**
** >mkdir router && touch router/router.js **

编辑一个最基本的router.js,包含两个页面home和page1:


import React from 'react';

import {BrowserRouter as Router, Route, Swich, Link} from 'react-router-dom';

import Home from '../pages/Home/Home';

import Page1 from '../pages/Page1/Page1';

const getRouter = () => (

 <Router>

 <div>

 <ul>

 <li><Link to="/">首页</Link></li>

 <li><Link to="/page1">Page1</Link></li>

 </ul>
 <Route exact path="" component={Home}/>

 <Route path="/page1" component={Page1}/>

 </div>
 </Router>
 );

 export default getRouter;

新建页面文件夹

cd src
mkdir pages

新建两个页面 Home,Page1

cd src/pages

mkdir Home && touch Home/Home.js

mkdir Page1 && touch Page1/Page1.js

填充内容:

src/pages/Home/Home.js

import React, {Component} from 'react';

export default class Home extends Component {
 render() {
 return (
 <div>This is Home</div>
 )
 }

}

这是点击link会在Console显示error, Failed to execute 'pushState' on 'History': A history state object with URL 'file:///D:/' cannot be created in a document with origin 'null' and URL 'file:///D:… /dist/app.html'。这是因为一直以来我们通过[file:///F:/react/react-family/dist/index.html](file:///F:\react\react-family\dist\index.html)路径访问html。不是我们想象中的路由那样的路径http://localhost:3000~。因此,我们需要配置一个简单的WEB服务器,指向index.html~有下面两种方法来实现:
① Nginx, Apache, IIS等配置启动一个简单的的WEB服务器。
② 使用webpack-dev-server来配置启动WEB服务器。

所以,下面对dev-server进行配置,在本文章后再对react-router做详细介绍。

(7) webpack-dev-server配置WEB服务器

webpack-dev-server就是一个小型的静态文件服务器。使用它,可以为webpack打包生成的资源文件提供Web服务。这里webpack-dev-server需要全局安装,要不后面用的时候要写相对路径。

a. 安装

npm install webpack-dev-server --save-dev
npm install webpack-dev-server -g

b. 添加 webpack.config.js配置


 devServer: {

 contentBase: path.join(__dirname, './dist')

 }

其中,contentBase指向文件根路径。

c. 添加运行指令

在package.json中添加

"start": "webpack-dev-server --config webpack.config.js"

执行 npm run start ,打开http://localhost:8080/查看效果

webpack-dev-server编译后的文件,都存储在内存中,我们并不能看见的。你可以删除之前遗留的文件dist/bundle.js,仍然能正常打开网站!

color(CLI only) console中打印彩色日志

historyApiFallback 任意的404响应都被替代为index.html。有什么用呢?你现在运行

npm start,然后打开浏览器,访问http://localhost:8080,然后点击Page1到链接http://localhost:8080/page1,然后刷新页面试试。发现刷新后404了。

<v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"><v:stroke joinstyle="miter"><v:formulas></v:formulas><v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"></v:path></v:stroke></v:shapetype><v:shape id="图片_x0020_1" o:spid="_x0000_i1025" type="#_x0000_t75" style="width:226.5pt;height:63pt;visibility:visible;mso-wrap-style:square"><v:imagedata src="file:///C:\Users\李以勋\AppData\Local\Temp\msohtmlclip1\01\clip_image001.png" o:title="" croptop="2285f" cropbottom="53587f" cropright="46171f"></v:imagedata></v:shape>

为什么?dist文件夹里面并没有page1.html,当然会404了,所以我们需要配置

historyApiFallback,让所有的404定位到index.html。

host 指定一个host,默认是localhost。如果你希望服务器外部可以访问,指定如下:host: "0.0.0.0"。比如你用手机通过IP访问。

hot 启用Webpack的模块热替换特性。

port 配置要监听的端口。默认就是我们现在使用的8080端口。

proxy 代理。比如在 localhost:3000 上有后端服务的话,你可以这样启用代理:


 proxy: {

 "/api": "http://localhost:3000"

}

progress(CLI only) 将编译进度输出到控制台。

根据这几个配置,修改下我们的webpack-dev-server的配置~


 devServer: {

 port: 8080,

 contentBase: path.join(__dirname, './dist'),

 historyApiFallback: true,

 host: '0.0.0.0'

}

CLI ONLY的需要在命令行中配置package.json


"dev": "webpack-dev-server --config webpack.dev.config.js --color --progress" ```

运行 npm start ,这个时候会发现编译正确,但是浏览器显示** Cannot GET /**。这是为什么呢?上面说到了,historyApiFallback,让所有的404定位到index.html。而我们代码中使用的是app.html,所以可以将app.html更换名字index.html或者使用:

historyApiFallback: {

rewrites: [

{ from: /./, to: './dist/app.html' }

]

}

初次之外,devServer还有一个hot属性,它是个布尔值,表示是否开启热替换模块,下面一节将讲到。

(8) Hot Module Replacement

从上可以发现,每当在js内修改内容,都需要重新编译。因此我们使用webpack的一个热替换插件Hot Module Replacement,当在编辑页面修改代码时,浏览器会自动刷新。使用功能如下:
在package.json 增加 --hot

"dev": "webpack-dev-server --config webpack.dev.config.js --color --progress --hot"


或者

在webpack.config.js中添加配置

  • const webpack = require('webpack');

  • devServer: { hot: true}

  • plugins:[ new webpack.HotModuleReplacementPlugin()]


我们分别尝试一下上面的配置,并使用下面的重置state案例:

修改Home.js,增加计数state

import React, {Component} from 'react';

export default class Home extends Component {

constructor(props) {

super(props);

this.state = {

count: 0

}

}

_handleClick() {

this.setState({

count: ++this.state.count

})

}

render() {

return (

<div>

This is Home

当前计数:{this.state.count}

<button onClick={() => this._handleClick()}>自增</button>

</div>

)

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351