dva.js 用法总结
程序员文章站
2022-07-07 09:07:59
dva.js是阿里前端团队开发的一个基于react、redux、webpack的一个前端框架,他能够完成react-redux-webpack环境一键部署,能帮前端工程师节省不少环境搭建的时间。而且经过优化的redux跟原生redux相比使用起来要方便不少。这里来大致讲一下dva.js的用法。 先全 ......
dva.js是阿里前端团队开发的一个基于react、redux、webpack的一个前端框架,他能够完成react-redux-webpack环境一键部署,能帮前端工程师节省不少环境搭建的时间。而且经过优化的redux跟原生redux相比使用起来要方便不少。这里来大致讲一下dva.js的用法。
先全局安装dva-cli
cnpm install dva-cli -g
使用dva-cli初始化应用:
dva new your-project-name
然后进入项目目录,新建文件dev.bat,内容如下:
call npm run start
保存后双击dev.bat即可开启开发服务器,并出现初始页面。
这里我们用一个加法计数器来作为演示。
1、routes文件夹内新建demo.js以及demo.css
import {connect} from 'dva' import styles from './demo.css' function demo({dispatch,num}) { //dispatch用来操作数据模型。 function Add() { console.log(num); dispatch({ type:"num/add" //num代表数据模型,add代表方法。这里可以通过payload来传递参数。 }) } return( <div className={styles.checkNum}> <input type="button" value="+" onClick={Add}/> <input type="input" value={num}/> <input type="button" value="-"/> </div> ) } export default connect( //将组件与数据模型进行连接。 ({num})=>({num}) )(demo);
demo.css:
.checkNum{ width: 300px; height: 100px; border: 1px solid #ccc; }
models文件夹新建文件num.js
export default { namespace:'num', state:0, reducers:{ 'add'(state){ //num可以理解为数据模型,state是数据的初始值,add是方法名,用来修改num用的。如果需要传参可参考官方教程。(payload) state++; return state } } }
前往src下的index.js,注册num数据模型:
import dva from 'dva'; import './index.css'; // 1. Initialize const app = dva(); app.model(require('./models/num').default); app.router(require('./router').default);
这步如果粗心的话就容易遗漏,务必小心。
src文件夹下的router.js内添加demo路由:
import React from 'react'; import { Router, Route, Switch } from 'dva/router'; import IndexPage from './routes/IndexPage'; import demo from './routes/demo' function RouterConfig({ history }) { return ( <Router history={history}> <Switch> <Route path="/" exact component={IndexPage} /> <Route path="/demo" exact component={demo} /> </Switch> </Router> ); } export default RouterConfig;
这时,访问http://localhost:8000/#/demo即可看到成果。
dva.js官方案例:
https://ant.design/docs/react/practical-projects-cn
github:
上一篇: 车好多集团完成15亿美元融资 加大产品技术研发投入
下一篇: asp.net excel导出功能
推荐阅读
-
NodeJS加密解密及node-rsa加密解密用法详解
-
网站反向链接最优化操作总结
-
Python3.4学习笔记之 idle 清屏扩展插件用法分析
-
Python3.4学习笔记之常用操作符,条件分支和循环用法示例
-
PHP超级全局变量【$GLOBALS,$_SERVER,$_REQUEST等】用法实例分析
-
C#中String StringBuilder StringBuffer类的用法
-
Laravel框架Eloquent ORM新增数据、自定义时间戳及批量赋值用法详解
-
深入探讨:oracle中row_number() over()分析函数用法
-
oracle case when 语句的用法详解
-
ASP.NET C#中Application的用法教程