摘要:官方推薦結(jié)合使用更配哦,其實(shí)他們都是同一位開發(fā)者開發(fā)的,屬于阿里內(nèi)部開源框架。但是名字必須為,不然不能自動注冊。只有一個的話,可以不用建目錄。可能是我理解有誤。
umi官方推薦結(jié)合dva使用更配哦,其實(shí)他們都是同一位開發(fā)者開發(fā)的,屬于阿里內(nèi)部開源框架。1 修改.umirc.js,開啟dva支持
// ref: https://umijs.org/config/ export default { plugins: [ // ref: https://umijs.org/plugin/umi-plugin-react.html ["umi-plugin-react", { antd: true, dva: true, dva: { immer: true }, dynamicImport: false, title: "umis", dll: false, hardSource: false, routes: { exclude: [ /components//, ], }, }], ], }2 修改layouts
先搞一個后臺的布局,可以參考ANT DESIGN PRO https://pro.ant.design/
layoutsindex.js
import styles from "./index.less"; import { Layout, Menu, Breadcrumb, Icon } from "antd"; import { Component } from "react"; import Link from "umi/link"; import logo from "../assets/logo.svg"; const {Header, Content, Footer, Sider} = Layout; const SubMenu = Menu.SubMenu; class BasicLayout extends Component { constructor(props) { super(props); this.state = { collapsed: false, }; } toggle = () => { this.setState({ collapsed: !this.state.collapsed, }); } render(){ return (); } } export default BasicLayout; Ant Design Pro
{/*此處可加面包屑*/} { this.props.children }
layoutsindex.less
.logo { height: 64px; position: relative; line-height: 64px; transition: all 0.3s; background: #002140; overflow: hidden; img { display: inline-block; vertical-align: middle; height: 32px; } h1 { color: white; display: inline-block; vertical-align: middle; font-size: 20px; margin: 0 0 0 12px; font-family: "Myriad Pro", "Helvetica Neue", Arial, Helvetica, sans-serif; font-weight: 600; } } .trigger { font-size: 18px; line-height: 64px; padding: 0 24px; cursor: pointer; transition: color .3s; .logo { height: 32px; background: rgba(255,255,255,.2); margin: 16px; } } .sider { min-height: 100vh; box-shadow: 2px 0 6px rgba(0, 21, 41, 0.35); position: relative; z-index: 10; &.ligth { background-color: white; .logo { background: white; h1 { color: #002140; } } } }
瀏覽器訪問你會看到如下效果:
在pages下創(chuàng)建users目錄
創(chuàng)建index.js 會生成默認(rèn)路由http://localhost:8000/users
import { connect } from "dva"; import { Table, Pagination, Popconfirm } from "antd"; import styles from "./users.css"; const PAGE_SIZE = 5; function Users({ list: dataSource, total, page: current }) { function deleteHandler(id) { console.warn(`TODO: ${id}`); } const columns = [ { title: "Name", dataIndex: "name", key: "name", render: text => {text}, }, { title: "Email", dataIndex: "email", key: "email", }, { title: "Website", dataIndex: "website", key: "website", }, { title: "Operation", key: "operation", render: (text, { id }) => ( EditDelete ), }, ]; return (record.id} pagination={false} />
); } function mapStateToProps(state) { const { list, total, page } = state.users; console.log(state.test); return { list, total, page, }; } export default connect(mapStateToProps)(Users); 創(chuàng)建對應(yīng)的model.js,因?yàn)橹挥幸粋€model所以不需要創(chuàng)建models目錄。但是名字必須為model.js,不然不能自動注冊。
//只有一個model的話,可以不用建models目錄。但名字必須為model。js import * as usersService from "./service"; export default { namespace: "users", state: { list: [], total: null, }, reducers: { save(state, { payload: { data: list, total } }) { return { ...state, list, total }; }, }, effects: { *fetch({ payload: { page } }, { call, put }) { const { data} = yield call(usersService.fetch, { page }); yield put({ type: "save", payload: { data, total: data.length } }); }, }, subscriptions: { setup({ dispatch, history }) { return history.listen(({ pathname, query }) => { if (pathname === "/users") { dispatch({ type: "fetch", payload: query }); } }); }, }, };創(chuàng)建service.js 這個不需要約定名稱,你隨便起名字
import request from "../../utils/request"; export function fetch({ page = 1 }) { return request(`/api/users?_page=${page}&_limit=5`); }創(chuàng)建utils目錄,封裝統(tǒng)一請求api utils equest.js
import fetch from "dva/fetch"; function checkStatus(response) { if (response.status >= 200 && response.status < 300) { return response; } const error = new Error(response.statusText); error.response = response; throw error; } /** * Requests a URL, returning a promise. * * @param {string} url The URL we want to request * @param {object} [options] The options we want to pass to "fetch" * @return {object} An object containing either "data" or "err" */ export default async function request(url, options) { const response = await fetch(url, options); checkStatus(response); const data = await response.json(); const ret = { data }; return ret; }創(chuàng)建mock假數(shù)據(jù) mockuser.js
export default { "/api/users": [ { "id": 1, "name": "Leanne Graham", "username": "Bret", "email": "Sincere@april.biz", "address": { "street": "Kulas Light", "suite": "Apt. 556", "city": "Gwenborough", "zipcode": "92998-3874", "geo": { "lat": "-37.3159", "lng": "81.1496" } }, "phone": "1-770-736-8031 x56442", "website": "hildegard.org", "company": { "name": "Romaguera-Crona", "catchPhrase": "Multi-layered client-server neural-net", "bs": "harness real-time e-markets" } }, { "id": 2, "name": "Ervin Howell", "username": "Antonette", "email": "Shanna@melissa.tv", "address": { "street": "Victor Plains", "suite": "Suite 879", "city": "Wisokyburgh", "zipcode": "90566-7771", "geo": { "lat": "-43.9509", "lng": "-34.4618" } }, "phone": "010-692-6593 x09125", "website": "anastasia.net", "company": { "name": "Deckow-Crist", "catchPhrase": "Proactive didactic contingency", "bs": "synergize scalable supply-chains" } }, { "id": 3, "name": "Clementine Bauch", "username": "Samantha", "email": "Nathan@yesenia.net", "address": { "street": "Douglas Extension", "suite": "Suite 847", "city": "McKenziehaven", "zipcode": "59590-4157", "geo": { "lat": "-68.6102", "lng": "-47.0653" } }, "phone": "1-463-123-4447", "website": "ramiro.info", "company": { "name": "Romaguera-Jacobson", "catchPhrase": "Face to face bifurcated interface", "bs": "e-enable strategic applications" } }, { "id": 4, "name": "Patricia Lebsack", "username": "Karianne", "email": "Julianne.OConner@kory.org", "address": { "street": "Hoeger Mall", "suite": "Apt. 692", "city": "South Elvis", "zipcode": "53919-4257", "geo": { "lat": "29.4572", "lng": "-164.2990" } }, "phone": "493-170-9623 x156", "website": "kale.biz", "company": { "name": "Robel-Corkery", "catchPhrase": "Multi-tiered zero tolerance productivity", "bs": "transition cutting-edge web services" } }, { "id": 5, "name": "Chelsey Dietrich", "username": "Kamren", "email": "Lucio_Hettinger@annie.ca", "address": { "street": "Skiles Walks", "suite": "Suite 351", "city": "Roscoeview", "zipcode": "33263", "geo": { "lat": "-31.8129", "lng": "62.5342" } }, "phone": "(254)954-1289", "website": "demarco.info", "company": { "name": "Keebler LLC", "catchPhrase": "User-centric fault-tolerant solution", "bs": "revolutionize end-to-end systems" } }, { "id": 6, "name": "Mrs. Dennis Schulist", "username": "Leopoldo_Corkery", "email": "Karley_Dach@jasper.info", "address": { "street": "Norberto Crossing", "suite": "Apt. 950", "city": "South Christy", "zipcode": "23505-1337", "geo": { "lat": "-71.4197", "lng": "71.7478" } }, "phone": "1-477-935-8478 x6430", "website": "ola.org", "company": { "name": "Considine-Lockman", "catchPhrase": "Synchronised bottom-line interface", "bs": "e-enable innovative applications" } }, { "id": 7, "name": "Kurtis Weissnat", "username": "Elwyn.Skiles", "email": "Telly.Hoeger@billy.biz", "address": { "street": "Rex Trail", "suite": "Suite 280", "city": "Howemouth", "zipcode": "58804-1099", "geo": { "lat": "24.8918", "lng": "21.8984" } }, "phone": "210.067.6132", "website": "elvis.io", "company": { "name": "Johns Group", "catchPhrase": "Configurable multimedia task-force", "bs": "generate enterprise e-tailers" } }, { "id": 8, "name": "Nicholas Runolfsdottir V", "username": "Maxime_Nienow", "email": "Sherwood@rosamond.me", "address": { "street": "Ellsworth Summit", "suite": "Suite 729", "city": "Aliyaview", "zipcode": "45169", "geo": { "lat": "-14.3990", "lng": "-120.7677" } }, "phone": "586.493.6943 x140", "website": "jacynthe.com", "company": { "name": "Abernathy Group", "catchPhrase": "Implemented secondary concept", "bs": "e-enable extensible e-tailers" } }, { "id": 9, "name": "Glenna Reichert", "username": "Delphine", "email": "Chaim_McDermott@dana.io", "address": { "street": "Dayna Park", "suite": "Suite 449", "city": "Bartholomebury", "zipcode": "76495-3109", "geo": { "lat": "24.6463", "lng": "-168.8889" } }, "phone": "(775)976-6794 x41206", "website": "conrad.com", "company": { "name": "Yost and Sons", "catchPhrase": "Switchable contextually-based project", "bs": "aggregate real-time technologies" } }, { "id": 10, "name": "Clementina DuBuque", "username": "Moriah.Stanton", "email": "Rey.Padberg@karina.biz", "address": { "street": "Kattie Turnpike", "suite": "Suite 198", "city": "Lebsackbury", "zipcode": "31428-2261", "geo": { "lat": "-38.2386", "lng": "57.2232" } }, "phone": "024-648-3804", "website": "ambrose.net", "company": { "name": "Hoeger LLC", "catchPhrase": "Centralized empowering task-force", "bs": "target end-to-end models" } } ], }訪問http://localhost:8000/users
4 總結(jié)按umi推薦的方式去創(chuàng)建目錄
注意約定名 pages目錄下的所有js都回被默認(rèn)生成路由,可通過配置排出
省略了model的手動注冊,至于忽略namespace,我試了不行
各個page的model不能相互引用?不是很明白什么意思,我試了每個page都能獲取所有的state,并不是只能獲取屬于自己的。可能是我理解有誤。
沒有看出來umi的好處,只是目錄的區(qū)別嗎?
這個 issues 下有關(guān)于umi按page分的討論。https://github.com/sorrycc/bl...
希望知道umi核心優(yōu)勢的小伙伴留言解釋下,前端菜鳥不是很懂。別忘了關(guān)注我 mike啥都想搞
還有其他后端技術(shù)分享在我的公眾號。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/100943.html
相關(guān)文章
從項(xiàng)目中由淺入深的學(xué)習(xí)react (2)
摘要:序列文章從項(xiàng)目中由淺入深的學(xué)習(xí)微信小程序和快應(yīng)用前言從和原生兩個項(xiàng)目來介紹的使用搞懂這兩個項(xiàng)目上手?jǐn)]代碼篇效果圖項(xiàng)目歡迎技術(shù)棧路由版本狀態(tài)管理組件字體適配方案適配技能點(diǎn)分析技能點(diǎn)對應(yīng)的種定義組件方法函數(shù)式定義的無狀態(tài)組 showImg(https://segmentfault.com/img/bVbqPvN?w=820&h=512); 序列文章 從項(xiàng)目中由淺入深的學(xué)習(xí)vue,微信小程序...
Umi.js
摘要:,中文可發(fā)音為烏米,是一個可插拔的企業(yè)級應(yīng)用框架。以路由為基礎(chǔ)的,支持類的約定式路由,以及各種進(jìn)階的路由功能,并以此進(jìn)行功能擴(kuò)展,比如支持路由級的按需加載。全局存于目錄,所有頁面都可引用頁面不能被其他頁面所引用。 umi,中文可發(fā)音為烏米,是一個可插拔的企業(yè)級 react 應(yīng)用框架。umi 以路由為基礎(chǔ)的,支持類 next.js 的約定式路由,以及各種進(jìn)階的路由功能,并以此進(jìn)行功能擴(kuò)展...
發(fā)表評論
0條評論
beita
男|高級講師
TA的文章
閱讀更多
#便宜#RackNerd:雙十一優(yōu)惠,2核/2G/30G SSD/4T/1Gbps/年付$18,多機(jī)
閱讀 874·2021-10-25 09:45
ftp如何訪問主機(jī)-怎樣訪問ftp服務(wù)器上的文件?
閱讀 3298·2021-09-22 14:58
henghost,中國香港云服務(wù)器簡單測評,電信cn2 gia,聯(lián)通移動各自骨干直連
閱讀 3856·2021-08-31 09:43
【前端芝士樹】IE 靜態(tài)頁兼容指南
閱讀 919·2019-08-30 15:55
圖像映射——我的web前端自學(xué)之路進(jìn)行時2
閱讀 923·2019-08-29 13:51
【轉(zhuǎn)】ng-class的用法
閱讀 1235·2019-08-29 13:02
React 實(shí)踐項(xiàng)目 (一)
閱讀 3490·2019-08-29 12:52
初識vue之a(chǎn)xios的封裝
閱讀 1965·2019-08-26 13:27
閱讀需要支付1元查看