vue Composables 组合式函数

官方文档在这里 cn.vuejs.org/guide/reusa...

作用

提取复杂逻辑,复用更方便。

例子

ts 复制代码
<script setup lang="ts">
import { useUserStatus } from '@/composables/useUserStatus'

const props = defineProps<{ user: User }>()
const { isOnline, statusText } = useUserStatus(props.user)
</script>

@是路径src/composables/useUserStatus

要自己写逻辑。

实现useUserStatus:

js 复制代码
// 模拟 useUserStatus composable
function useUserStatus() {
    const isOnline = ref(true);
    const lastChanged = ref(new Date().toLocaleTimeString());
    
    function toggleStatus() {
        isOnline.value = !isOnline.value;
        lastChanged.value = new Date().toLocaleTimeString();
    }
    
    function simulateNetworkChange() {
        // 随机改变状态来模拟网络变化
        if (Math.random() > 0.5) {
            isOnline.value = true;
        } else {
            isOnline.value = false;
        }
        lastChanged.value = new Date().toLocaleTimeString();
    }
    
    return {
        isOnline,
        lastChanged,
        toggleStatus,
        simulateNetworkChange
    };
}
相关推荐
帅帅哥的兜兜18 小时前
猪齿鱼 table表单编辑
前端
白兰地空瓶18 小时前
你以为树只是画图?不——它是算法面试的“隐形主角”
前端·javascript·算法
张拭心18 小时前
为什么说 AI 视频模型不能用来做教育?Sora-2 Veo-3 来了也不行
前端·人工智能
lvchaoq19 小时前
页面停留时间过长导致token过期问题
前端
elangyipi12319 小时前
深入理解前端项目中的 package.json 和 package-lock.json
前端·json
LYFlied19 小时前
【算法解题模板】-【回溯】----“试错式”问题解决利器
前端·数据结构·算法·leetcode·面试·职场和发展
composurext19 小时前
录音切片上传
前端·javascript·css
程序员小寒19 小时前
前端高频面试题:深拷贝和浅拷贝的区别?
前端·javascript·面试
狮子座的男孩19 小时前
html+css基础:07、css2的复合选择器_伪类选择器(概念、动态伪类、结构伪类(核心)、否定伪类、UI伪类、目标伪类、语言伪类)及伪元素选择器
前端·css·经验分享·html·伪类选择器·伪元素选择器·结构伪类
zhougl99619 小时前
Vue 中的 `render` 函数
前端·javascript·vue.js