版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、React全家桶2课堂目标1. 掌握umi2. 掌握redux解决方案-dva3. 掌握generator4. 掌握redux-saga资源1. umi2. dva3. redux-saga:中文、英文4. generator知识要点1. umi架构思想和用法2. 状态管理解决方案dva起步redux-saga使用安装:npm install -save redux-saga使用:用户登录redux-saga实现创建./store/sagas.js开课吧web全栈架构师import call, put, takeEvery from "redux-saga/effects"
2、/ 模拟登录const UserService = login(uname) return new Promise(resolve, reject) => setTimeout() => if (uname = "Jerry") resolve( id: 1, name: "Jerry", age: 20 ); else reject("用户名或 错误");, 1000);修改user.redux.jsexport const user = (state = isLogin: false, loading: false,
3、error: "" , action) => switch (action.type) case "requestLogin":return isLogin: false, loading: true, error: "" ; case "loginSuccess":return isLogin: true, loading: false, error: "" ; case "loginFailure":return isLogin: false, loading: f
4、alse, error: action.message ; default:return state;export function login(uname) return type: "login", uname ;/ export function login() / return dispatch => / dispatch( type: "requestLogin" );/ setTimeout() => / dispatch( type: "login" );/ , 2000);/ ;/ redux-saga,.
5、/store/index.js开课吧web全栈架构师);/ worker Sagafunction* login(action) try yield put( type: "requestLogin" );const result = yield call(UserService.login, action.uname); yield put( type: "loginSuccess", result ); catch (message) yield put( type: "loginFailure", message );funct
6、ion* mySaga() yield takeEvery("login", login);export default mySaga;import user from "./user.redux"import createSagaMiddleware from "redux-saga" import mySaga from "./sagas"const sagaMiddleware = createSagaMiddleware(); const store = createStore(combineReducer
7、s( user ), applyMiddleware(logger, sagaMiddleware);sagaMiddleware.run(mySaga); export default store;使用状态,RouteSample.jsconst Login = connect( state => (isLogin: state.user.isLogin, loading: state.user.loading, error: state.user.error / 登录错误), login )( location, isLogin, login, loading, error ) =&
8、gt; / 登录错误const redirect = location.state.redirect | "/"const uname, setUname = useState(""); / 用户名输入状态if (isLogin) return <Redirect to=redirect />return (<div><p>用户登录</p><hr />/* 显示错误 */error && <p>error</p>/* 输入用户名 */<inputty
9、pe="text"onChange=e => setUname(e.target.value) value=uname/>/* 登录传参 */<button onClick=() => login(uname) disabled=loading>loading ? "登录中." : "登录"</button></div>););#开课吧web全栈架构师React企业级应用程序框架 - Umi全局安装umi: npm install umi -g新建 index页umi g page
10、 index umi g page about起服务看效果 umi dev动态路由:以$开头的文件或目录/ 创建users/$id.js,内容和其他页面相同,显示一下传参export default function(props) return (<div><h1>user id: props.match.params.id</h1></div>);嵌套路由/ 创建父组件 umi g page users/_layout export default function(props) return (<div><h1>Pag
11、e _layout</h1><div>props.children</div></div>)/ 创 组件 umi g page users/index页面跳转开课吧web全栈架构师/ 用户列表跳转至用户详情页, users/index.jsimport Link from "umi/link" import router from "umi/router"export default function() / 模拟数据const users = id: 1, name: "tom" ,
12、id: 2, name: "jerry" ; return (<div className=styles.normal><h1>用户列表</h1><ul>users.map(u => (/ 式/ <li key=u.id>/ <Link to=/users/$u.id></Link>/ </li>/ 命令式<li key=u.id onClick=()=>router.push(/users/$u.id)></li>)&
13、lt;/ul></div>);配置式路由:默认路由为 式,根据pages下面内容自动生成路由,业务复杂后仍需配置路由/ 创建config/config.js export default routes: path: "/", component: "./index" ,path: "/users",component: "./users/_layout", routes: path: "/users/", component: "./users/index"
14、 , path: "/users/:id", component: "./users/$id" ;404页面:创建404页面: umi g page NotFound添加不带path的路由配置项: component: './NotFound'权限路由:通过配置路由的 Routes 属性来实现path: "/about", component: "./about",Routes: "./routes/PrivateRoute.js" / 这里相对根目录,文件名后缀不能少创建./r
15、outes/PrivateRoute.js开课吧web全栈架构师创建登录页面: umi g page login ,并配置路由: path: "/login", component: "./login" export default function() return (<div className=styles.normal><h1>Page login</h1></div>);引入antd添加antd: npm install antd -S添加 umi-plugin-react: npm instal
16、l umi-plugin-react -DWin10 限错误,通过管理员权限打开vscode 修改./cong/cong.jsplugins: 'umi-plugin-react', antd: true,import Button from 'antd' export default () => return <div><Button>登录</Button></div>引入dva开课吧web全栈架构师import Redirect from "umi/redirect"export de
17、fault props => / 50%概率需要去登录页面if (Math.random()>0.5) return <Redirect to="/login" />return (<div><div>PrivateRoute (routes/PrivateRoute.js)</div>props.children</div>);配置dvaexport default plugins: 'umi-plugin-react', antd: true,dva: true,/ .创建m :维护
18、页面数据状态新建./m s/goods.jsexport default namespace: 'goods', / m 名空间,区分多个mstate: title: "web全栈" , title: "java架构师" , / 初始状态effects:, / 异步操作reducers: / 更新状态 使用状态:创建页面goods.js: umi g page goods ,并配置路由: path: "/goods", component: "./goods" import React, Compo
19、nent from "react" import Button, Card from "antd" import connect from "dva"connect( state => (goodsList: state.goods / 获取指定命名空间的模型状态),addGood: title => (type: "goods/addGood", / action的type需要以命名空间为前缀+reducer名称payload: title )class Goods extends Component
20、 render() return (<div>/* 商品列表 */<div>ps.goodsList.map(good => return (<Card key=good.title>开课吧web全栈架构师<div>good.title</div></Card>);)<div><Button onClick=() =>ps.addGood("商品" + new Date().getTime()>添加商品</Button>&l
21、t;/div></div></div>);export default Goods;更新模型src/m s/goods.jsexport default reducers: addGood(state, action) return .state, title: action.payload.title;数据mock:模拟数据接口mock目录和src平级,新建mock/goods.jslet data = title:"web全栈",title:"java架构师"export default 'get /api/goods': function (req, res) setTimeout() => res.json(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 贵州城市职业学院《建筑设备(给水排水)》2023-2024学年第一学期期末试卷
- 贵阳职业技术学院《水文统计学与水文信息处理》2023-2024学年第一学期期末试卷
- 2025年天津市建筑安全员C证(专职安全员)考试题库
- 有机黄芪标准化种植项目可行性研究报告-有机黄芪市场需求持续扩大
- 2025山东建筑安全员C证考试题库
- 广州中医药大学《中学生物学教材分析与教学设计》2023-2024学年第一学期期末试卷
- 2025青海省建筑安全员B证考试题库及答案
- 2025福建省安全员-B证考试题库附答案
- 2025甘肃省建筑安全员-B证考试题库及答案
- 2025江西建筑安全员-B证考试题库及答案
- 穴位注射的机理与其在临床上的应用课件
- 学校校史编纂工作方案
- 农产品质量安全法解读
- 2024年石油石化技能考试-钻井工具装修工历年考试高频考点试题附带答案
- 人体器官有偿捐赠流程
- 青岛版数学五年级下册第二单元《分数的意义和性质》教学评一致性的单元整体备课
- 清朝的八旗制度及其影响
- 拇外翻护理查房课件
- 2023年采购电子主管年度总结及下一年展望
- 高考语用必考点-理解词语的含义+课件
- 混凝土采购组织供应、运输、售后服务方案
评论
0/150
提交评论