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

一.采用工具来实现(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

相关推荐
LaughingZhu1 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫2 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
杜子不疼.2 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号32 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
小鹏linux2 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
sycmancia3 小时前
Qt——编辑交互功能的实现
开发语言·qt
石山代码3 小时前
C++ 内存分区 堆区
java·开发语言·c++
前端若水3 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger3 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
无风听海3 小时前
C# 隐式转换深度解析
java·开发语言·c#