封装---统一封装处理页面标题

一.采用工具来实现(setPageTitle.ts)

多个页面中用更统一的方式设置 document.title,可以封装一个工具函数:

在utils目录下新建文件:setPageTitle.ts

如果要在每个页面设置相同的网站标志可以使用下面的appName

TypeScript 复制代码
const appName: string = import.meta.env.VITE_APP_NAME

export function setPageTitle(title: string) {
  if (typeof document !== 'undefined') {
    document.title = `${title} - ${appName}`
  }
}

其中的appName定义在.nev文件中:.nev

TypeScript 复制代码
# 设置名字
VITE_APP_NAME = "DevMentor"

使用时直接导入这个工具使用

二.封装为组件使用

我这里采用svelte框架示例,其他vue,react大差不差

TypeScript 复制代码
<script lang="ts">
  export let title: string
  const appName: string = import.meta.env.VITE_APP_NAME
  const fullTitle: string = `${appName}-${title}`
</script>

<svelte:head>
  <title>{fullTitle}</title>
</svelte:head>

使用:

TypeScript 复制代码
<PageTitle title="用户管理" />

三.在vue中的的路由设置

如果你使用 Vue Router(通常用于多页 SPA),可以这样统一控制标题。

TypeScript 复制代码
{
  path: '/paper/edit',
  name: 'EditPaper',
  component: () => import('@/views/Paper/Edit.vue'),
  meta: {
    title: '编辑试卷'
  }
}

如果需要动态设置:

TypeScript 复制代码
router.beforeEach((to, from, next) => {
  const title = to.meta?.title
  if (title) {
    document.title = `MyAdmin - ${title}`; // 可加前缀
  }
  next();
});

上面两个代码在一个文件中;router/index.ts

相关推荐
lbh3 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
小王不爱笑1323 小时前
IO 模型
开发语言·python
知我Deja_Vu3 小时前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
AI+程序员在路上4 小时前
CANopen 协议:介绍、调试命令与应用
linux·c语言·开发语言·网络
2401_831824964 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct4 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
qq_406176144 小时前
深入浅出 Pinia:Vue3 时代的状态管理新选择
javascript·vue.js·ecmascript
m0_518019484 小时前
C++与机器学习框架
开发语言·c++·算法
wefly20174 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
ZTLJQ4 小时前
深入理解逻辑回归:从数学原理到实战应用
开发语言·python·机器学习