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

网站做等级测评app开发公司推荐

网站做等级测评,app开发公司推荐,技术支持 东莞网站建设母婴护理,莱芜网站建设与管理UMI 生成react项目目录介绍及配置 react项目目录介绍umi多种配置方案运行时配置app.ts 的使用 1、umi创建的项目目录大致如下 ├─package.json 配置依赖以及启动打包所需的命令 ├─.umirc.ts 配置文件,包含 umi 内置功能和插件的配置 ├── dist 打包后生成的…

UMI 生成react项目目录介绍及配置

  • react项目目录介绍
  • umi多种配置方案
  • 运行时配置app.ts 的使用

1、umi创建的项目目录大致如下

├─package.json 配置依赖以及启动打包所需的命令
├─.umirc.ts 配置文件,包含 umi 内置功能和插件的配置
├── dist 打包后生成的文件
├── .env 环境变量 例如 端口
├─mock mock接口
└─src ├─.umi umi中间文件├─layouts 手动创建:布局路由时的全局布局文件├─pages 页面└─app.ts 手动创建:全局运行时配置

2、下面详细介绍各个目录

1) package.json

包含插件和插件集,以 @umijs/preset-、@umijs/plugin-、umi-preset- 和 umi-plugin- 开头的依赖会被自动注册为插件或插件集。用UMI创建项目会自动生成。

2) .umirc.ts

配置文件,包含 umi 内置功能和插件的配置。用UMI创建项目会自动生成。

3) .env

环境变量,自行配置,需手动创建,非必需。

4) dist 目录

执行 umi build 后,产物默认会存放在这里。打包后默认生成.

5) layouts/index.tsx

约定式路由时的全局布局文件。需手动创建,非必需。

6) pages 目录

所有路由组件存放在这里。用UMI创建项目会自动生成。

7) app.ts

运行时配置文件,可以在这里扩展运行时的能力,比如修改路由、修改 render 方法等。需手动创建,非必需。

UMI 配置

Umi 在 .umirc.ts 或 config/config.ts 中配置项目和插件,支持 es6。一份常见的配置如下,

export default {base: '/docs/',publicPath: '/static/',hash: true, history: {type: 'hash', // 路由类型},
}

项目配置 (3种配置路由的方式)

如果项目的配置不复杂,推荐在 .umirc.ts 中写配置; 如果项目的配置比较复杂,可以将配置写在 config/config.ts 中,并把配置的一部分拆分出去,比如路由配置可以拆分成单独的 routes.ts:

方式一: 路由在.umirc.ts中配置

import { defineConfig } from 'umi';
export default defineConfig({nodeModulesTransform: {type: 'none',},layout: {},hash:true,history: {type: 'hash',},routes: [{ path: '/', component: '@/pages/index' },],fastRefresh: {},
});

方式二: 路由在外部配置

// config/routes.ts

export default [{ exact: true, path: '/', component: 'index' },
];

// config/config.ts

import { defineConfig } from 'umi';
import routes from './routes';export default defineConfig({routes: routes,
});

提示路由在外部配置后,.umirc.ts中对routes的配置要移除,.umirc.ts 优先级更高,会把其他覆盖

export default defineConfig({// routes: [//   { path: '/', component: '@/pages/index' },// ],fastRefresh: {},
});

方式三:路由一部分在在外部配置一部分在.umirc.ts中配置

import { defineConfig } from 'umi';
import routes from './config/router';export default defineConfig({routes: [{ path: '/', component: '@/pages/index' },...routes],fastRefresh: {},
});

提示:如果你想在写配置时也有提示,可以通过 umi 的 defineConfig 方法定义配置

本地临时配置

可以新建 .umirc.local.ts,这份配置会和 .umirc.ts 做 deep merge 后形成最终配置。
注:.umirc.local.ts 仅在 umi dev 时有效。umi build 时不会被加载。

例如 在 .umirc.ts

import { defineConfig } from 'umi';
export default defineConfig({routes: [{ path: '/', component: '@/pages/index' },],
});

在.umirc.local.ts中写入

import { defineConfig } from 'umi';
export default defineConfig({routes: [{ exact: true, path: '/hello1', component: '@/pages/Hello' },],
});

运行发现,两个路由都可以生效

多环境多份配置

可以通过环境变量 UMI_ENV 区分不同环境来指定配置。例如 配置.umirc.local.ts(上面已经配置了)和.umirc.test.ts,
.umirc.test.ts

import { defineConfig } from 'umi';
export default defineConfig({routes: [{ exact: true, path: '/hello1', component: '@/pages/Test' },],
});

在.env文件中配置

UMI_ENV = test

执行发生,生效的是.umirc.test.ts,效果如图所示

运行时配置

UMI 运行时配置 app.ts配置

1、修改 clientRender 参数(适用微前端)

比如在微前端里动态修改渲染根节点,后期微服务可能会用到

let isSubApp = false;
export function modifyClientRenderOpts(memo) {return {...memo,rootElement: isSubApp ? 'sub-root' : memo.rootElement,    };
}

打印 memo的值,memo值包含plugin、rootElement、routes(路由)在这里插入图片描述

2、patchRoutes({ routes }) (修改路由)

修改路由:比如在最前面添加一个 /foo 路由,这个比较常见就用网上的例子

export function patchRoutes({ routes }) {routes.unshift({path: '/foo',exact: true,component: require('@/extraRoutes/foo').default,});
}

3、render (适用权限控制)

覆写 render,可用于渲染前的控制,例如权限控制

// 权限控制 比如用于渲染之前做权限校验
export function render(oldRender) {fetch('/api/auth').then(auth => {if (auth.isLogin) { oldRender() }else { history.push('/login'); oldRender()}});
}

4、onRouteChange({ routes, matchedRoutes, location, action })

在初始加载和路由切换时做一些事情。

  • routes:全部路由
  • matchedRoutes: 匹配到的路由信息
  • location: 当前的location
  • action: 当前路由变化的行为 例如 push
export function onRouteChange({ routes, matchedRoutes, location, action  }) {console.log('onRouteChange: routes, matchedRoutes, location, action',routes, matchedRoutes, location, action)if (matchedRoutes.length) {document.title = matchedRoutes[matchedRoutes.length - 1].route.title || '标题修改中';}
}

打印 routes, matchedRoutes, location, action的值,如下图
在这里插入图片描述

5、rootContainer(LastRootContainer, args)

修改交给 react-dom 渲染时的根组件。例如渲染时根组件时,外部包裹一层

export function rootContainer(container) {return React.createElement(ThemeProvider, null, container);
}

args 包含:

  • routes,全量路由配置
  • plugin,运行时插件机制
  • history,history 实例
http://www.hkea.cn/news/607481/

相关文章:

  • 交警网站建设整改百度推广怎么推广
  • 重庆网站建设哪里比较好呢网站下载
  • 网站运行速度慢的原因看b站二十四小时直播间
  • 电商网站开发服务全网营销骗局揭秘
  • 个人网站怎么做互联网营销师培训课程免费
  • 微信网站建设价格网站开发报价方案
  • wordpress utc时间慢8小时大连seo关键词排名
  • 中国建设承包商网站创建软件平台该怎么做
  • 中小企业网站建设费用海外推广服务
  • 企业名称的英文做网站名seo是怎么优化推广的
  • 手机在线建站西安seo服务公司
  • 网站开发有前途吗我也要投放广告
  • 备案 网站名称怎么写crm软件
  • 扁平式网站模板b2b网站推广优化
  • 做外贸网站网络营销咨询服务
  • 江门网站建设方案报价淘宝seo优化怎么做
  • 盘龙城做网站推广网站推广
  • 如何做电子书网站域名站长工具
  • 物联网平台有哪些排名优化外包公司
  • 秦皇岛汽车网站制作数字营销工具
  • 培训教育的网站怎么做东莞做网站的联系电话
  • 云南做网站的公司外贸谷歌优化
  • 网页设计学徒培训可试学巢湖seo推广
  • 让顾客心动的句子seo模拟点击软件源码
  • 设计类专业包括哪些kj6699的seo综合查询
  • 手机网站制作哪家好查关键词
  • 米拓企业网站管理系统电商培训机构排名前十
  • 做效果图有哪些网站seo点击排名
  • 网络营销推广网站收录seo推广排名平台有哪些
  • 产品经理如何看待网站开发广州软件系统开发seo推广