vue3 自定义网站title的hooks

在开发网页的时候会遇到,每个页面需要有自己的标题的需求,这样的话每个页面都需要写重复的代码。

通过hooks封装之后,页面上只需要一行代码就能搞定。

具体实现代码如下:

封装的title hooks

javascript 复制代码
import { ref,watchEffect,onUnmounted } from 'vue'

export function useTitle(title:string,restoreOnUnMount = true){
    const cTitle = document.title;
    const titleRef = ref(title);
    watchEffect(()=>{
        document.title = titleRef.vaule;
    })
    if(restoreOnUnMount){
        onUnmounted(() => {
            document.title = cTitle;
        })
    }
    const setTitle = (title:string) =>{
        titleRef.value = title;
    }
    return setTitle
}

在页面引入hooks,写下边代码

javascript 复制代码
const setTitle = useTitle('测试标题')
相关推荐
用户5806139393001 分钟前
前端文件下载实现深度解析:Blob与ObjectURL的完美协作
前端
Lin86664 分钟前
Vue 3 + TypeScript 组件类型推断失败问题完整解决方案
前端
coding随想4 分钟前
从零开始:前端开发者的SEO优化入门与实战
前端
前端工作日常7 分钟前
我理解的JSBridge
前端
Au_ust7 分钟前
前端模块化
前端
顺丰同城前端技术团队7 分钟前
还不会用 Charles?最后一遍了啊!
前端
BUG收容所所长8 分钟前
二分查找的「左右为难」:如何优雅地找到数组中元素的首尾位置
前端·javascript·算法
彬师傅8 分钟前
geojson、csv、json 数据加载
前端
用户52709648744909 分钟前
🔥 我与 ESLint 的爱恨纠葛:从"这破玩意儿"到"真香警告"
前端
梨子同志9 分钟前
手动实现 JavaScript 的 call、apply 和 bind 方法
前端·javascript