摘要:是一个用开发的一个企业级中后台管理包含常用的业务,组件,及数据流转方案,前后端分离的开发方式,按业务划分的目录结构,可以大大提高我们的开发效率下面是整体的介绍,感兴趣的同学可以去官网详加了解。
dva-boot-admin 是一个用React开发的一个企业级中后台管理UI,包含常用的业务,组件,及数据流转方案,前后端分离的开发方式,按业务划分的目录结构,可以大大提高我们的开发效率
下面是整体的介绍,感兴趣的同学可以去官网详加了解。
功能封装了dva框架的数据流转,简单的请求可以不用在model和service中定义
封装了数据模模拟,可以独立于后台开发前台功能
封装了分页请求,简化并规范了分页逻辑
封装了fetch请求,适应与后台多种交互请求, body参数 parameter参数 path参数,动态请求头,请求前后拦截
扩展了antd写了许多实用的UI,通过一个配置生成即可生成,后台CRUD三件套
按业务模块划分的目录结构,尽量做到最小耦合
一些常用的小部件用法
许多精心设计的页面及交互场景
dva-boot脚手架封装的功能
全局异常处理,全局请求拦截,公共配置提取
目录结构. ├── public # 不参与编译的资源文件 ├── src # 主程序目录 │ ├── index.js # 程序启动和渲染入口文件 │ ├── components # 全局公共组件 │ ├── layouts # 页面结构组件 │ │ ├── BasicLayout # 基本布局 │ │ └── OtherLayout # 布局组件根据具体功能调整,在路由配置中引用 │ ├── routes # 动态路由目录(每个功能一个文件夹的MVC结构) │ │ ├── index.js # 路由配置文件 │ │ ├── Home # 功能模块 │ │ │ ├── index.js # 路由配置文件 │ │ │ ├── assets # 多带带属于这个模块的静态资源文件 │ │ │ ├── components # 页面组件 │ │ │ ├── model # dva model │ │ │ ├── service # dva service │ │ │ └── routes ** # 子路由(目录结构与父级相同) │ │ └── Login # 功能模块 │ │ ├── index.js # 路由配置文件 │ │ ├── assets # 多带带属于这个模块的静态资源文件 │ │ ├── components # 页面组件 │ │ ├── model # dva model │ │ ├── service # dva service │ │ └── routes ** # 子路由(目录结构与父级相同) │ ├── utils # 工具类 │ └── assets # 资源文件 │ ├── fonts # 字体 & 字体图标 │ ├── images # 图片 │ └── styles # 全局样式常用方法 modelEnhance
modelEnhance是对dva model层的简单包装函数,有时候我们只是想要简单的fetch一下,从服务端获取数据进行展示,之前可能要专门在model中写一些effects和reducers,在service中定义请求函数,如果用modelEnhance包装一下的话可以简写成下面的形式
// src/routes/UserInfo/model/index.js import modelEnhance from "@/utils/modelEnhance"; // 就是普通的dva model传入modelEnhance即可,不用定义其它变量 export default modelEnhance({ namespace: "userInfo", }); // src/routes/UserInfo/components/index.js // 在组件中直接发出一个类型为`@request`的action, // 结果会存入userInfo对应的state中,使用的key为`valueField`的值 this.props.dispatch({ type: "userInfo/@request", payload: { url: "http://httpbin.org/get", valueField: "httpbin", method: "GET" } }); // 同时请求两个 this.props.dispatch({ type: "userInfo/@request", payload: [{ url: "http://httpbin.org/get", valueField: "httpbin", method: "GET" }, { url: "http://httpbin.org/post", valueField: "httpbin" }] }); // 结合分页助手使用,查询第1页10条数据 this.props.dispatch({ type: "userInfo/@request", payload: { valueField: "pageData", url: "/api/userInfo/getList", pageInfo: pageData.startPage(1, 10), } });exception
全局异常处理,我们可以在src/config.js的exceptiion中处理通用异常,这里共实就是dva的onError方法的入口,我们一般处理如登录超时,用户没有权限,或另种请求异常等,建议大家不同的异常可以多带带包装成一个异常类进行分类处理,这样更容易维护以及调试。
config工程的配置文件
fetch mock模拟服务端响应数据,常常用在前后端分离的项目中,我们在开发新功能的时候,前后端是不同步的,这时我们就会创建一些数据原型,协商好后这时后端就可以开始开发,而我们可以继续使用模拟数据,只有当后端完成这个接口并测试通过后,二者才会被整合。这之后如果后端因为某些原因服务不可用时,我们也会很方便的切换回模拟数据,这样不会因为后端的问题而影响后续的开发。
要新建一些模拟数据只要在__mocks__文件夹中,创建一个文件,并在文件夹中的index.js中进行声明,一些例子可以直接在文件夹下面找到。
所有的模拟数据是在开发环境中运行的,当您打包成生产环境的包时,会自动屏蔽所有模拟数据接口。
// 例子: /src/__mocks__/userInfo.js /** * 模拟请求数据 * @param {FetchMock} fetchMock 当现有条件不满足时,可以使用fetchMock来进行扩展 * @param {number} delay 增加延迟时间 ms * @param {function} mock 使用mock生成数据,例如: mock({ "string|1-10": "★" // 生成最少1颗,最多10颗星字符 }) // {"string": "★★★★★★"} */ export default ({fetchMock, delay, mock}) => { // 如果现有扩展不满足需求,可以直接使用fetchMock方法 // fetchMock.mock(/httpbin.org/post/, {/* response */}, {/* options */}); return { // 一般用法 "GET /api/getUserInfo": { name: "jonn" }, // 省略 method, 模拟真实请求延迟效果 "/api/getUsers": delay([ { name: "jonn" }, { name: "weiq" }, ]), // 表格带分页 "/api/userInfo/getList": delay(mock({ "pageNum|+1": 1, // 递增加1 "pageSize": 10, "size": 10, "total": 500, "totalPages": 50, "list|10": [{ "name": "@cname", // 中文名称 "age|1-100": 100, // 100以内随机整数 "birthday": "@date("yyyy-MM-dd")", // 日期 "city": "@city(true)", // 中国城市 "phone": /^1[385][1-9]d{8}/ // 手机号 }], })), // 表格带分页, 写成函数形式可以使用请求参数, // 更真实的模拟后端数据处理业务 "/api/userInfo/getList1": (options) => { const body = JSON.parse(options.body); const pageNum = body.pageNum; const idbase = (pageNum - 1) * 10 + 1; return toSuccess(mock({ "pageNum": pageNum, "pageSize": 10, "size": 10, "total": 100, "totalPages": 10, "list|10": [{ "id|+1": idbase, "name": "@cname", // 中文名称 "age|1-100": 100, // 100以内随机整数 "birthday": "@date("yyyy-MM-dd")", // 日期 "city": "@city(true)", // 中国城市 "phone": /^1[385][1-9]d{8}/ // 手机号 }], }), 400) } } }page helper (简单分页)
在做后台系统的时候,做的最多的可能就是对表格的增、删、改、查,这时我们的页面一般是这样的,上面是对表格条件的检索框,中间是我们的数据表格,表格下面是分页组件,还会有新增,修改时用到表单组件
拿对表格数据进行检索这个场景来说,在搜索框(可能有多个)输入条件,点击搜索,检索到结果(可能非常多),我们会点击下面的分页组件进行翻页,翻页时我们就得带着之前的检索条件,我们会在发送请求前手动合并这些条件,并计算下一页的页数等
而PageHelper分页助手就是为了简化我们的代码量的,如使用PageHelper.create()这个方法会为我们自动生成分页对象
// model.js state: { pageData: PageHelper.create() }
这时我们可以在组件中使用这个对象很方便的进行分页,及检索,并且支持链式写法,所有条件会自动进行合并,如:
// components const {pageData} = this.props; // 查询第1页,每页10条,并且name为jonn的数据 pageData.startPage(1, 10).filter({name: "jonn"}).filter(...).sortBy(...); // 查询下一页,并且会带着之前的查询条件 pageData.nextPage();
我们还可以结合modelEnhance来使用分页,更多用法会在例子中进行说明。
cmn-utils脚手架使用了cmn-utils做为工具库,这里面提供了请求、存储、事件等许多实用方法
开发&运行$ git clone https://github.com/LANIF-UI/dva-boot.git $ cd dva-boot $ yarn $ yarn start // 或使用npm $ npm install $ npm start
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/107801.html
摘要:前台演示网站地址小随笔后台演示网站地址小随笔后台演示网站账户密码资源有点大,可能要加载一段时间兼容方面目前还是主推荐用浏览器吧备注因为项目是一直在写的,周期比较长,改了又改,代码可能比较乱,大家能看则看,有意见的,直接提意见,发出来的目的, Kite This is a vue + react project kite 前台演示网站地址: 小随笔https://www.xiaosuib...
摘要:项目开发准备描述项目技术选型接口接口文档测试接口启动项目开发使用脚手架创建项目开发环境运行生产环境打包运行管理项目创建远程仓库创建本地仓库配置将本地仓库推送到远程仓库在本地创建分支并推送到远程如果本地有修改新的同事克隆仓库如果远程修 day01 1. 项目开发准备 1). 描述项目 2). 技术选型 3). API接口/接口文档/测试接口 2. 启动项目开发 1). 使用react...
摘要:面试造航母,工作拧螺丝,新公司面试技术官要求会技术栈。然而公司项目暂时并没有用到,不过为了提升实战经验,还是在业余时间捣腾出一个,以下是项目介绍。前段为了学习小程序的开发,做了个小程序名叫口袋吉他,这也是个人兴趣驱使的开发想法。 面试造航母,工作拧螺丝,新公司面试技术官要求会react技术栈。 问:有使用过React么?答:没,只使用过Vue。又问:给你一星期能上手开发么?答:可以(一...
摘要:一种通知请求成功的。对于这种,可能会把接收到的新数据合并到中,并重置。另外,有些会保存这些失败信息,并在里显示出来。 一、redux基础 redux 通过 dispatch(action) -> 中间件 -> reducer处理数据 -> 改变store -> 使用subscribe()监听store改变更新视图 的方式管理状态 将所有状态存储在一个store对象里面 reducer...
阅读 3687·2021-11-25 09:43
阅读 2647·2021-11-25 09:43
阅读 3846·2021-11-24 09:38
阅读 698·2021-11-18 10:02
阅读 2239·2021-09-22 15:53
阅读 3001·2019-08-30 15:44
阅读 2775·2019-08-30 14:01
阅读 2755·2019-08-29 15:15