【vue+ts】性能优化,defer优化白屏

代码:

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

export function useDefer(maxCount = 100) {
    const count = ref(0)
    let raqId:any = null;
    function updateFrame() {
        count.value++
        if (count.value >= maxCount) {
            return;
        }
        raqId = requestAnimationFrame(updateFrame)
    }
    updateFrame();
    onUnmounted(() => {
        cancelAnimationFrame(raqId)
    })
    return function (n:number) {
        return count.value >= n
    }
}

用法:

html 复制代码
<template>
    <IndexBbsRotationcArea :homeData="homeData" v-if="defer(1)" />
    <IndexBbsRecommendArea v-if="defer(2)" />
    <IndexBbsRecommendArea v-if="defer(3)" />
    <IndexBbsRecommendArea v-if="defer(4)" />
    <IndexBbsRecommendArea v-if="defer(5)" />
</template>

<script setup lang="ts">
    import { useDefer } from "~/utils/defer";
    const defer = useDefer();
</script>
相关推荐
Aric_Jones22 分钟前
JavaScript 从入门到精通:完整语法指南
开发语言·javascript·ecmascript
岱宗夫up28 分钟前
FastAPI入门(上篇):快速构建高性能Python Web API
开发语言·前端·python·fastapi
紫陌涵光1 小时前
112. 路径总和
java·前端·算法
漠月瑾-西安1 小时前
CVE-2025-55182漏洞解析:你的React项目安全吗?
前端·安全·react.js
No丶slovenly1 小时前
flutter笔记-输入框
前端·笔记·flutter
国产化创客2 小时前
ESP32+Web实现智能气象站
前端·物联网·智能家居·智能硬件
coderYYY3 小时前
VSCode终端启动报错
前端·ide·vscode·npm·编辑器
西门吹-禅3 小时前
文本搜索node js--meilisearch
开发语言·javascript·ecmascript
tod1133 小时前
Redis 数据类型与 C++ 客户端实践指南(redis-plus-plus)
前端·c++·redis·bootstrap·html
Sylvia33.3 小时前
火星数据:棒球数据API
java·前端·人工智能