前端开发小技巧 - 【Vue】 - 给页面设置 动态标题 和 静态标题

前言

  • 在我们做项目的时候,这肯定是要给项目设置网页标题的,这里设置就分为两种:
    • 静态 网页标题
      • 整个项目从始至终就使用一个标题,不随着路径(路由)的变化而变化;
    • 动态 网页标题
      • 不同的页面有不同的标题,随着路径(路由)的切换,页面标题需要发生变化;
  • 下面就来说说,我目前知道的几种设置页面标题的方案吧;
    • 后续遇到了别的方式也会补充上的

一、静态标题

1.1 路由守卫中设置

  • 注意

    • 可以在 全局前置守卫 或者 全局后置守卫 中设置;
  • 代码展示:

    ts 复制代码
    // 导入vue-router
    // 实例化路由
    // ...
    
    // 路由前置守卫
    router.beforeEach((to, from) => {
      document.title = '想要设置的标题';
    });
    
    // 全局后置守卫
    router.afterEach((to, from) => {
      documnet.title = '想要设置的标题';
    });

说明

  • 在这两个钩子函数中设置标题本质上没有太大区别;
  • 唯一的区别就在于:
    • 前置守卫
      • 先看到标题,再看到页面;
    • 后置守卫
      • 先看到页面,再看到标题;
  • 在一个页面跳转到另一个页面的时候,跳转之前会 对路由进行解析加载异步组件 ,这是一个 耗时 的过程。如果受到网速的影响,页面加载的速度可能有点慢,大家可以根据这点选择在哪个守卫函数中设置标题;

1.2 给Webpack增添配置项设置

  1. 修改 index.html<title>标签内容:

    html 复制代码
    <title>
      <%= webpackConfig.name %>
    </title>
  2. 设置标题:

    • 在项目的根目录下添加.env文件;

      ini 复制代码
      VUE_APP_TITLE = '天翼云办公工作台'
    • 配置Webpack:

      • 目标文件:
        • vue.config.js
      js 复制代码
      const { VUE_APP_TITLE } = process.env;
      const name = VUE_APP_TITLE || '默认标题';
      
      module.exports = {
        // ...
      
        configureWebpack: { name }
      
        // ...
      };

1.3 使用插件

  • 适用于 Vue2 项目;
  1. 安装插件

    • npm i vue-wechat-title --save
  2. main.js导入注册插件

    js 复制代码
    import Vue from 'vue';
    import VueWechatTitle from 'vue-wechat-title';
    
    Vue.use(VueWechatTitle);
  3. 给路由添加 meta 属性:

    js 复制代码
    // 举例
    const routes = [
    // ...
    
     {
        path: '/home',
        component: () => import('@/views/Home.index.vue'),
        meta: { title: '首页' }
     },
     
     // ...
    ]
  4. 设置标题:

    html 复制代码
    <router-view v-mechat-title="$router.meta.title" />
  5. 设置完成后,重启项目即可;

说明

  • 如果遇到不能生效的情况,请大家自行百度一下哈;
  • 这个插件我没使用过😂😂😂;
  • 抱歉哈;

1.4 ❌ 修改index.htmltitle标签的内容

  • 了解即可;
  • Vue2 项目:
    • 我们可以首手动修改index.html<title>标签的内容;
    • 文件所在位置:项目/public/index.html
  • Vue3 项目:
    • 也是可以直接修改index.html<title>标签的内容;
    • 文件位置:项目/index.html

二、动态标题

  • 动态标题
    • 随着页面的变化,网页的标题也会变化;
  • 要想实现动态标题,就必须借助于路由守卫
  • 注意
    • 可以在 全局前置守卫 或者 全局后置守卫 中设置;
  1. 给路由添加meta属性;

    ts 复制代码
    import type { RouteRecordRaw } from 'vue-router';
    // 举例
    const routes: RouteRecordRaw[] = [
    // ...
    
    {
       path: '/home',
       component: () => import('@/views/Home.index.vue'),
       meta: { title: '首页' }
    },
    
    // ...
    ]
  2. 在全局守卫中设置标题:

    ts 复制代码
    // 导入vue-router
    // 实例化路由
    // ...
    
    // 路由前置守卫
    router.beforeEach((to, from) => {
      document.title = to?.meat.title || '默认标题';
    });
    
    // 全局后置守卫
    router.afterEach((to, from) => {
      documnet.title = to?.meat.title || '默认标题';
    });

说明

  • 在这两个钩子函数中设置标题本质上没有太大区别;
  • 唯一的区别就在于:
    • 前置守卫
      • 先看到标题,再看到页面;
    • 后置守卫
      • 先看到页面,再看到标题;
  • 在一个页面跳转到另一个页面的时候,跳转之前会 对路由进行解析加载异步组件 ,这是一个 耗时 的过程。如果受到网速的影响,页面加载的速度可能有点慢,大家可以根据这点选择在哪个守卫函数中设置标题;
相关推荐
花归去2 小时前
vue3中 function getText(){} 、 const getText=()=>{} ;区别在哪里,优缺点
javascript·vue.js·ecmascript
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_33:(Attr 接口与属性节点的深入理解)
前端·javascript·ui·html·音视频·html5
神所夸赞的夏天2 小时前
如何获取多层json数据,存成dictionary,并取最大最小值
java·前端·json
红色的小鳄鱼2 小时前
前端面试js手写
开发语言·前端·javascript
焦糖玛奇朵婷2 小时前
健身房预约小程序开发、设计
java·大数据·服务器·前端·小程序
上海云盾王帅2 小时前
WEB业务如何接入安全防护:从零到一的实战指南
前端·安全
用户059540174462 小时前
AI Agent记忆丢失踩坑实录:这个问题让我排查了3天
前端·css
web行路人2 小时前
前端对Commands(斜杠命令)一些常用
前端·javascript·vue.js·vue
当时只道寻常2 小时前
从零到一打造企业级全栈后台管理系统 —— 技术选型、工程化实践与深度思考
前端·全栈·前端工程化
竹林8182 小时前
用 ethers.js 连 MetaMask 做钱包登录,我踩了三个坑才搞定跨页面状态同步
前端·javascript