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

潍坊方圆网站建设巢湖seo推广选哪家

潍坊方圆网站建设,巢湖seo推广选哪家,深圳网站设计公司设计,太原seo排名优化公司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.yayakq.cn/news/372176/

相关文章:

  • 连云港网站开发wordpress文章主图
  • 网站建设银行电商网站建设的内容
  • 番禺外贸型网站建设wap视频网站建设难吗?
  • 网站开发就业岗位山东东营市东营区邮编
  • seo网站是什么意思汕头市企业网站建设服务机构
  • 哪里可以买链接网站the author wordpress
  • 备案需要网站吗发果怎么做视频网站
  • iis如何建立网站采集网站如何做
  • 网站底部模板源码editplus网站开发
  • 法治建设网站作用seo项目培训
  • 泉州网站制作案例网站热点关键词
  • 合肥做网站的网络公司商丘企业网站建设费用多少钱
  • 怎么能查到网站是哪个公司做的网站建设的电销
  • 建站 赚钱做房地产信息网怎么做
  • 深圳营销型定制网站开发1000网站开发公司 logo
  • zen cart 网站google plus自己做的网站别人怎么访问
  • 企业网站软件下载做婚恋网站代理商挣钱吗
  • 美食网站建设的时间进度表短视频平台开发
  • 网站开发公司广告文案电子产品代加工怎么找货源
  • 做seo推广网站网站开发市场调查
  • 建设银行官方网站个人pc微信二维码永久入口
  • 网站视频是什么软件做的九江建企业网站
  • 云南域名注册网站建设网站相册源码
  • linux做网站的好处如何做外贸网店
  • 只要做好关键词优化深圳seo优化公司唯八seo
  • 快速做网站教程网站建设与推广协议书
  • 阿里云网站建设部署与发布试题答案深圳网站制作公司流程
  • 凤凰网站ui专业设计韩国优秀网站设计欣赏
  • 做公司标志用哪个网站高级服装定制
  • 上海网站排名团队菏泽住房与城乡建设官网