前端开发小技巧 - 【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 小时前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保2 小时前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun3 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp3 小时前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.4 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl6 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫7 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友7 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理9 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻9 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js