start

如何开始

开始之间最好先了解一下dva.js和create-react-app.

如何得到一个干净的工程结构

  1. routers目录为页面文件夹,routes下的index.js为页面配置文件,除了这个文件,其它文件都是可选的。Blank,是一个空页面示例,我们可以复制这个快速生成一个路由页面。Login,是登录页面;Register是注册页面。
  2. 留下我们需要的页面,把其它多余的文件夹删掉。
  3. 打开routes下的index.js,我们要在这里面配置路由页面:
import {createRoutes} from '@/utils/core';
import BasicLayout from '@/layouts/BasicLayout';
import UserLayout from '@/layouts/UserLayout';
import NotFound from './Pages/404';
import Login from './Login';
import Register from './Register';
import Blank from './Blank';

const routesConfig = (app) => ([
  {
    path: '/sign',              // url 地址
    title: '登录',
    indexRoute: '/sign/login',  // 默认路由
    component: UserLayout,      // 页面布局
    childRoutes: [
      Login(app),               // 子路由页面
      Register(app),
      NotFound()                // 这个要放到最下面,当所有路由当没匹配到时会进入这个页面
    ]
  }, {
    path: '/',
    title: '系统中心',
    component: BasicLayout,
    indexRoute: '/blank', // 默认路由
    childRoutes: [
      Blank(app),
      NotFound(), // 这个要放到最下面,当所有路由当没匹配到时会进入这个页面
    ]
  }
]);

export default app => createRoutes(app, routesConfig);

新建一个页面

首先在src/routes下建一个路由文件夹,形式可仿造src/routes/Blank,路由页面由四部分组成,components,model,service,index.js

components视图页面

这部分由index.js和页面自已的样式index.less组成,下面是一个标准的空路由页面:

@connect() // dva connect
export default class extends BaseComponent {
  render() {
    return (
      <Layout className="full-layout page blank-page">
        <Content className={style.className}>空白页</Content>
      </Layout>
    );
  }
}

最外层最好使用示例中的嵌套结构,Layout > Content,并且为每一个路由页面起一个自已的classNameidblank-page,这样我们写这个页面特定样式的时候从这个样式开始写,不会与其它路由页面产生冲突。

model 逻辑页面(dva model)- 非必需

model即为dvajs的model,推荐写法

import modelEnhance from '@/utils/modelEnhance';

export default modelEnhance({
  namespace: 'blank',
});

modelEnhance为框架封装,可以简化dvajs的写法,之后会专门介绍,如果不需要,可以完全按dvajs来编写我们的model

service 接口定义 (dva service) - 非必需

在这里定义我们的接口API, 如没有可以不写

index.js 定义子路由 - 必需

const routesConfig = app => ({
  path: '/blank',                // url
  title: 'blank page', // 页面标题
  component: dynamicWrapper(app, [import('./model')], () => import('./components')) // 如果没有 model 可以不写import('./model')
});

注册新页面到全局路由

在routers下的index.js里加入我们新写的页面即可。

配置路由到左侧菜单

在菜单的模拟数据里src/__mocks__/user.js增加我们新写的这个路由页面

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容