当前位置: 首页 > news >正文

金华网站建设外包手机维修培训班学校

金华网站建设外包,手机维修培训班学校,商务网站规划与网页制作,抖音里做我女朋友网站公司的项目源码用的是react和dva,所以我必须抓紧时间学习一下dva了,一天时间,看看我学到了什么(dva官网DvaJS)[这是很久之前就打算写的了,一直没时间,一直存着草稿,今天发出来吧] 1…

公司的项目源码用的是react和dva,所以我必须抓紧时间学习一下dva了,一天时间,看看我学到了什么(dva官网DvaJS)[这是很久之前就打算写的了,一直没时间,一直存着草稿,今天发出来吧]

1.介绍

dva 首先是一个基于 redux 和 redux-saga 的数据流方案,然后为了简化开发体验,dva 还额外内置了 react-router 和 fetch,所以也可以理解为一个轻量级的应用框架。【redux-saga】

2.安装 dva-cli

通过 npm 安装 dva-cli 并确保版本是 0.9.1 或以上。

$ npm install dva-cli -g
$ dva -v
dva-cli version 0.9.1

3. 创建新应用

dva new dva-quickstart

4. 通过 npm 安装 antd 和 babel-plugin-import 。babel-plugin-import 是用来按需加载antd 的脚本和样式的

$ npm install antd babel-plugin-import --save

编辑 .webpackrc,使 babel-plugin-import 插件生效。

{
+  "extraBabelPlugins": [
+    ["import", { "libraryName": "antd", "libraryDirectory": "es", "style": "css" }]
+  ]
}

注:dva-cli 基于 roadhog 实现 build 和 dev,

5.定义路由

新建 route component routes/Products.js,内容如下:

import React from 'react';const Products = (props) => (<h2>List of Products</h2>
);export default Products;

添加路由信息到路由表,编辑 router.js :

+ import Products from './routes/Products';
...
+ <Route path="/products" exact component={Products} />

npm start 启动服务

在浏览器里打开 http://localhost:8000/#/products ,你应该能看到前面定义的 <h2> 标签

6. 编写 UI Component

随着应用的发展,你会需要在多个页面分享 UI 元素 (或在一个页面使用多次),在 dva 里你可以把这部分抽成 component 。

我们来编写一个 ProductList component,这样就能在不同的地方显示产品列表了。

新建 components/ProductList.js 文件:

import React from 'react';
import PropTypes from 'prop-types';
import { Table, Popconfirm, Button } from 'antd';const ProductList = ({ onDelete, products }) => {const columns = [{title: 'Name',dataIndex: 'name',}, {title: 'Actions',render: (text, record) => {return (<Popconfirm title="Delete?" onConfirm={() => onDelete(record.id)}><Button>Delete</Button></Popconfirm>);},}];return (<TabledataSource={products}columns={columns}/>);
};ProductList.propTypes = {onDelete: PropTypes.func.isRequired,products: PropTypes.array.isRequired,
};export default ProductList;

7. 定义 Model

完成 UI 后,现在开始处理数据和逻辑。

dva 通过 model 的概念把一个领域的模型管理起来,包含同步更新 state 的 reducers,处理异步逻辑的 effects,订阅数据源的 subscriptions 。

新建 model models/products.js :

export default {namespace: 'products',state: [],reducers: {'delete'(state, { payload: id }) {return state.filter(item => item.id !== id);},},
};

这个 model 里:

  • namespace 表示在全局 state 上的 key
  • state 是初始值,在这里是空数组
  • reducers 等同于 redux 里的 reducer,接收 action,同步更新 state

然后别忘记在 index.js 里载入他:

// 3. Model
+ app.model(require('./models/products').default);

8. connect 起来

到这里,我们已经单独完成了 model 和 component,那么他们如何串联起来呢?

dva 提供了 connect 方法。如果你熟悉 redux,这个 connect 就是 react-redux 的 connect 。

编辑 routes/Products.js,替换为以下内容:

import React from 'react';
import { connect } from 'dva';
import ProductList from '../components/ProductList';const Products = ({ dispatch, products }) => {function handleDelete(id) {dispatch({type: 'products/delete',payload: id,});}return (<div><h2>List of Products</h2><ProductList onDelete={handleDelete} products={products} /></div>);
};// export default Products;
export default connect(({ products }) => ({products,
}))(Products);

最后,我们还需要一些初始数据让这个应用 run 起来。编辑 index.js

- const app = dva();
+ const app = dva({
+   initialState: {
+     products: [
+       { name: 'dva', id: 1 },
+       { name: 'antd', id: 2 },
+     ],
+   },
+ });

 9.打包

 npm run build
http://www.dt0577.cn/news/34720.html

相关文章:

  • 如何再国外网站做折扣目前推广平台都有哪些
  • 深圳 网站设计网盘资源共享网站
  • 无锡网站建设有限公司市场营销实际案例
  • 郑州网站建设汉狮老客外链
  • 十大门户网站有哪些广州网站建设推荐
  • 厦门网站建设哪家厦门建设银行seo排名工具提升流量
  • 建设书局 网站四川最好的网络优化公司
  • 有哪些网站可以免费做外销如何让百度收录自己信息
  • 东莞企业网站电话seo基本步骤
  • wordpress网站插件下载失败品牌传播方案
  • 软件公司网站系统集成建设短视频seo关键词
  • 自己做网站卖机器设备北京seo运营
  • 陕西网站建设策划内容关键词检测
  • 什么源码做有趣的网站搜索引擎优化简称
  • 做谷歌网站制作网站需要的技术与软件
  • vf建设银行网站新闻稿
  • thinkphp大型网站开发推销产品的万能句子
  • 如何做内网站的宣传栏精准网络营销推广
  • 住房和城乡建设部网站唐山手机网站制作
  • 东莞网站建设价格长沙网站优化排名推广
  • 网站开发子账号抖音怎么推广引流
  • 做网站go和pythongoogle官网进入
  • 成都系统定制seo工资水平
  • 网站建设南通网站建设与管理就业前景
  • 北京网站营销seo方案今日最新新闻摘抄
  • wordpress 禁用修订怎么把网站排名优化
  • 中山手机建网站友情链接实例
  • 麻城网站建设个人网上卖货的平台
  • 昆明做网站哪家便宜北京seo优化排名
  • 如何把网站上线怎么做表格