Vue动态修改网页标题
业务需求,进入页面的时候,网页有个默认标题,加载的网页内容不同时,标题需要变更. 例:功能授权,功能授权(张三).
Vue下有很多的方式去修改网页标题,这里总结下解决此问题的几种方案:
一、最笨方案
结合业务直接在Vue生命周期函数 created 和 mounted 中,给 document.title赋值。
- <script>
- import axios from 'axios'
- export default {
- created () {
- document.title = '功能授权'
- },
- mounted() {
- axios.get('***').then((d)=>{
- document.title = '功能授权('+ d.Name + ')'
- })
- }
- }
- </script>
二、普通方案,使用Vue-Router的beforeEach拦截
项目中使用了Vue Router,在路由文件 index.js 中给需要的路由添加 title。
- routes: [{
- path: '/',
- name: 'home',
- component: () => import('@/pages/home/index'),
- meta:{
- keepAlive: true
- }
- },
- {
- path: '/person/auth,
- name: 'personAuth',
- component: () => import('@/pages/person/auth),
- meta:{
- title: '功能授权',
- keepAlive: false
- }
- }
- ]
在路由的beforeEach 拦截器里处理
- router.beforeEach((to, from, next) => {
- /* 路由发生变化修改页面title */
- if (to.meta.title) {
- document.title = to.meta.title
- }
- })
如果想在页面上依据加载的内容不同再变更title时,请参考方式一的 mounted函数处理逻辑.
三、优雅方案,使用Vue 自定义指令(directive)
如前文所提,页面获取不同数据状态时,需要展示不同的标题。那么我们可以结合vue 自定义指令(directive)可更优雅的处理网页标题的动态更新。
自定义指令 v-web-title的定义
- export default {
- inserted: function (el, binding) {
- const { value } = binding
- if (el.dataset.title) { // 方式1,可以给标签的data-title的属性赋值
- document.title = el.dataset.title
- } else if (value && value.title) { // 方式2,指令传参
- document.title = value.title
- }
- },
- update (el, binding, vnode, oldVnode) {
- const { value } = binding
- if (el.dataset.title) {
- document.title = el.dataset.title
- } else if (value && value.title) {
- document.title = value.title
- }
- }
- }
在页面上使用v-web-title有两种方式
1.给标签 data-title属性赋值
- <template>
- <div v-web-title
- :data-title="textTitle">
- </template>
- <script>
- import axios from 'axios'
- export default {
- data(){
- return {
- textTitle:'功能授权'
- }
- },
- mounted () {
- axios.get('***').then((d) => {
- this.textTitle = '功能授权(' + d.Name + ')'
- })
- }
- }
- </script>
2.给指令传参
- <template>
- <div v-web-title="{title:textTitle}">
- </template>
- <script>
- import axios from 'axios'
- export default {
- data(){
- return {
- textTitle:'功能授权'
- }
- },
- mounted () {
- axios.get('***').then((d) => {
- this.textTitle = '功能授权(' + d.Name + ')'
- })
- }
- }
- </script>
四、参考
1. vue单页面应用中动态修改title 主要介绍使用vue-weachat-title组件
2.vue.js自定义指令详解 主要介绍自定义指令的钩子函数,以及指令传参等
Vue动态修改网页标题的更多相关文章
- jquery无法修改网页标题,无法修改网页标题
今天遇到一个问题,搜索时动态修改网页标题,用jquery的这段代码无效,无论FF还是IE $("title").html("new title"); 后来只好用 ...
- Vue 动态修改data 值 并触发视图更新
Vue 动态修改data 值 并触发视图更新 this.$set(obj, key, '') // Vue 动态修改或者添加data key 并触发视图更新
- 微信小程序动态修改页面标题setNavigationBarTitle
微信小程序是可以动态修改页面标题的. 首先我们来看看静态是怎么实现的 在对应页面的json文件里面加入下面代码就可以实现了 { "navigationBarTitleText": ...
- vue动态修改title
1.项目中,cmd下 ,运行:cnpm install vue-wechat-title --save 2.在 main.js 中,设置: import VueWechatTitle from 'vu ...
- 小程序动态修改页面标题setNavigationBarTitle
可以使用setNavigationBarTitle方法动态设置页面标题 wx.setNavigationBarTitle({ title: options.name, })
- 如何动态修改网页的标题(title)?
有时候我们需要复用一个页面,但是又希望他们拥有各自的标题,这时候就需要动态的去更改页面的title了,不然所有页面都是一个标题. 这时候就会想到使用js或jQuery去实现了. 1.js方式. 首先, ...
- 使用JS动态修改网页body的背景色
大部分网页默认的背景色为白色,个人感觉比较刺眼,于是写了个JS的脚本去改变body部分的背景色,代码如下: // ==UserScript== // @name ChangeBackgroundCol ...
- Vue动态修改class
#####对象方法-最简单的绑定(这里的active加不加单引号都可以,以下也一样都能渲染) :class="{ 'active': isActive }"1判断是否绑定一个act ...
- MFC 动态修改对话框标题
在对应对话框的初始化函数OnInitDialog()中添加以下代码: CString title; title.Format("%d",Id);//在标题栏动态显示Id的值 thi ...
随机推荐
- Awesome Java: Github上关于Java相关的工具
Awesome Java 这是Github上关于Java相关的工具,框架等等资源集合. 原文参考: https://github.com/akullpp/awesome-java. @pdai 最全的 ...
- Android中几种常用的定时器和延时方法
通过实际项目的练习,掌握了几种android基本定时器和延时的用法,这里我想总结一下作为自己的收获,下面列出的是比较简洁的模式,方便简单地在程序中直接调用. 一.三种常用的定时器 1.Handler类 ...
- FCC---Create a More Complex Shape Using CSS and HTML---一个粉色爱心
One of the most popular shapes in the world is the heart shape, and in this challenge you'll create ...
- leaflet-webpack 入门开发系列二加载不同在线地图切换显示(附源码下载)
前言 leaflet-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载地址 w ...
- 021.Docker mysql启动时执行初始化sql
1.拉取Mysql镜像 # docker pull mysql:5.7 2.检查mysql镜像 # docker inspect mysql:5.7 ## "Entrypoint" ...
- Autofac 应用于IIS托管的WEB程序,注册程序集被回收的问题
现项目开始全面接入Autofac,但上线了后发现,iis进程被回收后,在访问网页提示找不到注册在Autofac中的类型,或者实例.现在处理办法记录如下: 1. IIS托管的应用程序,在首次加载时,所有 ...
- MongoDB安装调试
1:安装 去mongodb的官网http://www.mongodb.org/downloads下载32bit的包 解压后会出现以下文件 在安装的盘C:下建立mongodb文件夹,拷贝bin文件夹到该 ...
- apicloud如何实现优雅的下拉刷新与加载更多
apicloud中提供下拉刷新监听事件api,也提供滚动到底部事件的监听,能够实现下拉刷新和滚动到底部加载更多功能,但是我们真的就满足实现功能了吗?将两个代码拼凑起来运行看看发现了什么?是的,在滚动到 ...
- Linxu:磁盘分区
了解磁盘分区 磁盘的物理组成: 圆形的磁盘盘(主要记录数据的部分): 机械手臂,与在机械手臂上的磁盘读取头(可擦写磁盘盘上的数据): 主轴马达,可以转动磁盘盘,让机械手臂的读取头在磁盘盘上读写数据. ...
- 初学JavaScript正则表达式(三)
正则表达式由两种基本的字符类型组成 原义文本字符 //a abc 1 元字符 元字符是有特使含义的非字母字符 * 匹配前面的子表达式零次或多次 + 匹配前面的子表达式一次或多次 ? 匹配前面的子表达式 ...