配置 react-router-dom

 

我们开发一个 React 工程肯定不是一两个“页面”就可以满足需求的,所以我们需要一个在多个“页面”中跳转的功能,在使用 React 构建的单页面应用中,要想实现页面间的跳转,首先想到的就是使用路由。

考虑 React 工程中的路由时,通常会想到 react-router 和 react-router-dom,其中 React-router 提供了一些 router 的核心 Api,包括 Router, Route, Switch 等,但是它没有提供 Dom 操作进行跳转的 Api,而 React-router-dom 让我们可以通过dom的事件控制路由。

由于我们这次只是搭建开发环境,所以就不再做更多的介绍,现在来做一个简单的说明,首先我们需要安装 react-router-dom:

$ yarn add react-router-dom

然后我们简单的使用一下,以验证安装的结果和使用的效果,我们先在跟组件 App 中的同目录下创建两个组件:

// Home.js
import React from 'react';
import { Link } from 'react-router-dom'; export default () => (
<div>
<div>home page</div>
<Link to="/product">go</Link>
</div>
); // Product.js
import React from 'react'; export default () => (
<div>product page</div>
);

然后我们在主组件 App 中引入相关的依赖并进行简单的使用:

import React from 'react';
import { BrowserRouter, Route } from 'react-router-dom'; import Home from './Home';
import Product from './Product'; const App = () => (
<BrowserRouter>
<div>
<Route path="/" exact component={Home} />
<Route path="/product" exact component={Product} />
</div>
</BrowserRouter>
); export default App;

现在我们进入项目时会在根目录下,所以会自动进入 Home 页面,当我们点击 go 字段的时候就会跳转到 Product 页面,也就意味着已经安装成功了。

配置 Redux

 

在 React 中有一个单项数据流的概念,在大型应用中单靠 React 对于数据的管理并不理想,所以我们需要依赖 Redux 来进行管理。

Redux 是一个面向 JavaScript 应用的可预测状态容器,它能够让你的页面的数据管理更轻松,现在我们就来对它进行安装并进行简单的使用,首先我们安装 Redux:

$ yarn add redux

然后我们在 src 目录下创建 store 目录,并添加 index.js 和 reducers.js 文件:

// index.js
import { createStore } from 'redux'; import reducer from './reducers'; const store = createStore(reducer); export default store; // reducers.js
const defaultState = {
text: 'Hello world',
}; /* 必须返回一个纯函数 */
export default (state = defaultState) => state;

最后我们改变一下 Home 组件以其来测试配置和使用的情况:

import React from 'react';
import { Link } from 'react-router-dom';
import store from './store'; class Home extends React.Component {
constructor(props) {
super(props); this.state = store.getState();
const { text } = this.state;
this.text = text;
} render() {
return (
<div>
<div>{this.text}</div>
<Link to="/product">go</Link>
</div>
);
}
} export default Home;

现在页面中的正常情况会显示 store 存储的数据,也就是“Hello world”字样。

配置 其它

 

接下来会对配置的对象列出一个列表来,就不再像之前这样在页面中同时列出做出的修改,如果有兴趣的同学,可以直接点击 show me the code 直接查看源码,也可以查看提交历史中对应 commit 中的内容。

毕竟主要是配置,使用方法三两句就说不清楚了,所以暂且这样:

最后,如果在开发中有使用到 Git 的话,那么结合 huskylint-staged 配置代码检查工作流将会非常的棒,在我们配置完成之后,每当我们提交时,都会执行代码检查工作,如果代码的书写不规范的话将会取消本次提交。

当然这两者的功能并不仅仅如此,感兴趣的朋友可以点击上面的链接了解更多,这里我们先来简单的配置体验一下它的功能,首先还是安装依赖:

$ yarn add husky lint-staged --dev

然后我们在 package.json 文件中对它们进行配置:

{
"scripts": {
"precommit": "lint-staged"
},
"lint-staged": {
"src/**/*.js": "eslint"
}
}

现在我们每次提价前就会执行代码检测啦,你可以特意书写一行不符合规范的代码来来进行测试。

环境的配置到这里就告一段落啦,这里更多的是介绍了 React 相关插件和库的安装,如果你想要知道最初的搭建步骤,你可以点击 搭建 webpack、react 开发环境(一) 来继续查看。如果你需要查看 webpack 方面的一些配置和插件的使用,以及一些可以优化的地方可以点击 搭建 webpack、react 开发环境(二) 来继续查看。

搭建 webpack、react 开发环境(三)的更多相关文章

  1. 从零开始搭建webpack+react开发环境

    环境主要依赖版本 webpack@4.8.1 webpack-cli@2.1.3 webpack-dev-server@3.1.4 react@16.3.2 babel-core@6.26.3 bab ...

  2. 搭建 webpack + React 开发环境

    说在开头 上个月断断续续的在研究webpack的配置,但是很多网上的文章基本上都是只说了开发环境的配置,而忽略了生产环境的配置.大致研究了一下门路,然后就来写一篇随笔让自己能在以后能有个地方可以做参考 ...

  3. Qemu搭建ARM vexpress开发环境(三)----NFS网络根文件系统

    Qemu搭建ARM vexpress开发环境(三)----NFS网络根文件系统 标签(空格分隔): Qemu ARM Linux 经过上一篇<Qemu搭建ARM vexpress开发环境(二)- ...

  4. 如何搭建 node,react 开发环境

    项目相关内容:Sublime + Node + React --注意:在 windows 操作系统中,如果把 node 安装在系统盘(一般是C盘),会导致 node 没有操作文件的权限的问题,如无法新 ...

  5. 「C语言」在Windows平台搭建C语言开发环境的多种方式

    新接触C语言,如何在Windows下进行C语言开发环境的搭建值得思考并整理. 以下多种开发方式择一即可(DEV C++无须环境准备). 注:本文知识来源于  Windows 平台搭建C语言集成开发环境 ...

  6. Qemu搭建ARM vexpress开发环境(二)----通过u-boot启动Linux内核

    Qemu搭建ARM vexpress开发环境(二)----通过u-boot启动Linux内核 标签(空格分隔): Qemu ARM Linux 在上文<Qemu搭建ARM vexpress开发环 ...

  7. Webpack笔记(二)——搭建React开发环境

    前几天一直在学习webpack,总算比之前学习的时候有了点收获,所以在昨天发布了一篇webpack入门笔记,今天继续使用webpack练了练手,搭建了一个React开发环境,如果还不熟悉的童鞋可以看一 ...

  8. 搭建 webpack、react 开发环境(二)

    配置处理样式文件   到目前为止,整个工程的配置已经差不多了,对于 React 更多相关的配置将在后面继续介绍,现在我们先来对目前的工程进行优化. 前面我们学习了搭建 webpack.react 开发 ...

  9. 搭建 webpack、react 开发环境(一)

    基本介绍   Webpack 是一个前端资源加载/打包工具.它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源,它可以将多种静态资源 JavaScript.css.le ...

随机推荐

  1. MVC模型的基本原理及实现原理

    [转载]MVC架构在Asp.net中的应用和实现 摘要:本文主要论述了MVC架构的原理.优缺点以及MVC所能为Web应用带来的好处.并以“成都市信息化资产管理系统”框架设计为例,详细介绍其在Asp.n ...

  2. NodeJs的CommonJS模块规范

    前言 本人记忆力一般,为了让自己理解<深入浅出Node.js-朴灵>一书,会在博客里记录一些关键知识,以后忘了也可以在这里找到,快速回想起来 Node通过require.exports.m ...

  3. ES5继承模式

    果然,感觉有些东西不整理一下还是很容易忘记的,很多时候有需要不断地去复习,感觉JavaScript这门语言总体上不能算是特别难,但是知识点特别杂(坑也特别多...),感觉最好还是能够梳理出一个整体架构 ...

  4. 关于手机端在同一个Grid中使用不同的布局展现即Layout的使用

    标题可能说的不是很清楚,我举个栗子好了,现在你正在写手机端的一个审批模块,这个模块要求能够展示所有待审批的信息 比如出差申请,请假申请,加班申请,以及报销申请 那么我的思路有两个 1:建立一个Tab页 ...

  5. linux性能分析工具Top

  6. linux time命令的输出中“real”“user”“sys”的真正含义

    下面转载的文章详细地介绍了time出来显示的“real”“user”“sys”的真正含义. Linux中time命令,我们经常用来计算某个程序的运行耗时,用户态cpu耗时,系统态cpu耗时. 例如: ...

  7. 第二节:链接mongodb服务器

    查看mongodb的使用说明 版本是3.6.0 options 选项 指的是用户名和密码 address 数据库地址  数据库格式是 ip:端口/数据库 192.168.0.5:999/foo 链接本 ...

  8. BZOJ2695 保护古迹

    非常带劲之计算几何 写的头晕= = 就是平面图转对偶图然后最小割 由于p非常小我们枚举所有保护状态然后割一下 建图真的烦 就是把区域划分出来看一下每一个古迹点是否被小区域包含[好像也可以写点定位] 然 ...

  9. python代码整体左移或右移

    IDE 是  PyCharm 选中代码块: 1)右移:直接 Tab 2)左移:Shift + Tab

  10. ajax处理返回的三种格式(json格式 , xml通用格式 , html文本格式)(数据类型:整数、字符串、数组、对象)(基础最重要!)

    ajax方法的参数 常用的ajax参数比如url,data,type,包括预期返回类型dataType,发送到服务器的数据的编码类型contentType,成功方法,失败方法,完成方法.除了这些以外还 ...