接上文:Uni&antd的ProLayout布局动态菜单实现及踩坑记录
在调整好菜单后,又发现一个问题,打开页面不显示标题,点击菜单的时候才会正常显示标题,再次点击当前菜单,标题又变的不太对了。
首次打开不显示标题
因为 umirc.ts 配置文件的 route 没有配置 title 配置后显示标题了:
routes: [
{
name: '首页',
title: '首页',
path: '/',
icon: 'home',
component: '@/pages/index',
},
...
],
因为给 ProLayout 配置了 title ,点击菜单时标题会变成 route.title - ProLayout.title 的形式(如:首页 – 前端资源网)。
但是有一个问题,在当前页面点击当前菜单,标题会变成 route.title ,ProLayout.title 不见了(如:首页),首次打开页面,不点击菜单的时候也只显示 route.title。
因为在 menuItemRender 用的是 Link 可能有 bug ,使用下面的方法来避免重复加载刷新:
menuItemRender={(item, dom) => <div onClick={() => {
if (item.path === location.pathname) {
return;
} else {
history.push(item.path);
}
}}>{dom}</div>}
注意这里的 history 是 Umi 的组件,需要引入一下:
import { history, Helmet } from 'umi';
这样只能避免重复刷新, title 还是有问题。
可以借助 <Helmet /> 动态修改页面的 title 标题(上面已经引入了):
import React, { useState, useEffect } from 'react';
const { route, location } = props;
//获取当前路由
const [title, setTitle] = useState('首页 - 前端资源网);
useEffect(() => {
const curRoute = _find(
route.routes,
(item) => item.path === location.pathname,
);
const title = curRoute
? `${curRoute.name} - 前端资源网`
: '前端资源网';
setTitle(title);
}, [location.pathname]);
这里需要用到 lodash 的 _find 组件,引入一下:
import _find from 'lodash/find';
如果没有安装 lodash 依赖,安装一下:
npm i --save-dev lodash // Or yarn add lodash
将 <Helmet /> 放在 <ProLayout /> 标签内即可,代码如下:
<ProLayout>
<Helmet>
<title>{title}</title>
</Helmet>
...
</ProLayout>
这样就可以动态修改页面的 title 了。
未经允许不得转载:w3h5 » Umi&React动态修改title标题
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/150542.html