项目学习笔记 display从none切换成block

跟着视频学做项目的时候,碰到一个多级联动列表,列表元素的display会从none切换成block,切换过程中可能导致资源渲染过多,从而导致卡顿问题。

javascript 复制代码
<div class="all-sort-list2">
    <div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"
        @mouseenter="setChooseIndex(index)">
        <h3 :class="{ chooseNow: nowIndex == index }">
            <a>{{ list_data1.categoryName }}</a>
        </h3>
        <div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }">
            <div class="subitem">
                <dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId">
                    <dt>
                        <a>{{ list_data2.categoryName }}</a>
                    </dt>
                    <dd>
                        <em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId">
                            <a>{{ list_data3.categoryName }}</a>
                        </em>
                    </dd>
                </dl>
            </div>
        </div>
    </div>
</div>

对于这个列表,其内部元素是从服务区获取数据,然后通过v-for显示。

类item-list的disblock会不断从none切换为block。

组件渲染导致使用卡顿

javascript 复制代码
<div class="all-sort-list2">
    <div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"
        @mouseenter="setChooseIndex(index)">
        <h3 :class="{ chooseNow: nowIndex == index }">
            <router-link>{{ list_data1.categoryName }}</router-link>
        </h3>
        <div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }">
            <div class="subitem">
                <dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId">
                    <dt>
                        <router-link>{{ list_data2.categoryName }}</router-link>
                    </dt>
                    <dd>
                        <em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId">
                            <router-link>{{ list_data3.categoryName }}</router-link>
                        </em>
                    </dd>
                </dl>
            </div>
        </div>
    </div>
</div>

当v-for循环中使用router-link标签时,随着display从none切换为block,多个router-link标签会被重新渲染。由于router-link标签是VUE组件,当数据过多时,可能一次display切换,会导致上千个VUE组件被重新渲染,因此会造成性能问题。

一个解决办法是可以把router-link换成a标签,再在a标签上绑定click事件处理。

回调函数被多次渲染

javascript 复制代码
<div class="all-sort-list2">
    <div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"
        @mouseenter="setChooseIndex(index)">
        <h3 :class="{ chooseNow: nowIndex == index }">
            <a @click="">{{ list_data1.categoryName }}</a>
        </h3>
        <div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }">
            <div class="subitem">
                <dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId">
                    <dt>
                        <a @click="">{{ list_data2.categoryName }}</a>
                    </dt>
                    <dd>
                        <em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId">
                            <a @click="">{{ list_data3.categoryName }}</a>
                        </em>
                    </dd>
                </dl>
            </div>
        </div>
    </div>
</div>

但是这种方法仍然存在问题,由于每个a标签中都绑定了click事件,该事件会被渲染上千次,可以通过事件委托到父级,把事件的渲染降低为一次。

(但这里其实我也不太懂,我觉得虽然事件生成了多个,但是其实不click就不会被调用,不调用也会影响性能吗)

解决办法是使用事件委托。

把事件绑定在父级上,然后通过event.target获得点击的标签,进行处理。

javascript 复制代码
<div class="all-sort-list2" @click="goSearch">
    <div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId" 
        ... 
    </div>
</div>

<script>
    ...
    goSearch(event){
        
        let e = event.target;
        
        getAttribute('...');
    }
</script>
相关推荐
超级大只老咪1 天前
快速进制转换
笔记·算法
嵩山小老虎1 天前
Windows 10/11 安装 WSL2 并配置 VSCode 开发环境(C 语言 / Linux API 适用)
linux·windows·vscode
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.1 天前
Keepalived VIP迁移邮件告警配置指南
运维·服务器·笔记
ling___xi1 天前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
星火开发设计1 天前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
Gorgous—l1 天前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
AndyHeee1 天前
【windows使用TensorFlow,GPU无法识别问题汇总,含TensorFlow完整安装过程】
人工智能·windows·tensorflow
远程修电脑→24169767751 天前
三角洲行动弹窗提示CPU虚拟化未开启或被占用启动腾讯游戏时出现【ACE安全中心】虚拟化相关报错
windows
188_djh1 天前
# 15_电脑版百度网盘每次登录都显示安全验证,很麻烦,一招解决
windows·app·百度网盘·百度网盘安全验证·baidudisk