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('测试标题')
相关推荐
用户58124415415712 小时前
GemDesign MCP协议详解:从原型到代码的完整技术链路
前端
半个烧饼不加肉13 小时前
JS 底层探究-- 事件循环
开发语言·前端·javascript
goDeep13 小时前
useMemo 和 useCallback 的区别,我终于搞懂了
前端
小亮学前端13 小时前
在1Panel中部署Nuxt项目
前端·vue.js
产品研究员13 小时前
AI生成可用的React交互代码实测:Lovable vs Stitch vs Paico
前端·react.js·aigc
labixiong13 小时前
Prompt 工程:当一段文字学会了思考、行动与统治
前端·ai编程
用户8417948145613 小时前
vxe-table 虚拟滚动下自定义行高:支持每行独立高度与自适应
vue.js
biubiubiu_LYQ13 小时前
入门开发者必学篇之JS事件循环:为什么你的代码输出总翻车?
前端·javascript
HwJack2013 小时前
鸿蒙背景下 Cocos Creator 的三大 JS 引擎:JIT 与热更新的十字路口
javascript·华为·harmonyos
程序员黑豆13 小时前
AI全栈开发之Java:怎么安装JDK
前端·ai编程·全栈