当前位置: 首页 > wzjs >正文

网站登录页面html模板站长工具爱情岛

网站登录页面html模板,站长工具爱情岛,网站制作教程ppt,网络营销做得比较好的企业跟着视频学做项目的时候&#xff0c;碰到一个多级联动列表&#xff0c;列表元素的display会从none切换成block&#xff0c;切换过程中可能导致资源渲染过多&#xff0c;从而导致卡顿问题。<div class"all-sort-list2"><div class"item" v-for&quo…

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

<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。

组件渲染导致使用卡顿

<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事件处理。

回调函数被多次渲染

<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获得点击的标签,进行处理。

<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>

http://www.dtcms.com/wzjs/514756.html

相关文章:

  • 论文网站的负载测试是如何做的广告销售如何寻找客户
  • 武汉网站建设排行山东服务好的seo
  • 对门户网站建设情况的报告网络营销的四大特点
  • 怎么利用招聘网站做薪酬调查一个网站如何推广
  • 学校网站建设要求seo服务建议
  • 泰州政府门户网站建设金花关键词工具
  • 网站建设云尚网络合肥网站排名提升
  • 网站建设与网页设计试卷招商外包公司
  • 28网站怎么做代理搜索优化指的是什么
  • 广州安全教育平台注册深圳排名seo
  • 如何让自己做的博客网站上线自媒体培训
  • 网站开发 估算 excel合肥网站优化平台
  • 网站建设如何把更改内容站长之家查询网
  • 网站建设外包合同免费b站在线观看人数在哪里找到
  • 北京丰台区网站建设企业管理咨询培训
  • seo网站推广怎么做杭州关键词优化测试
  • 做自己的彩票网站百度收录查询api
  • 网站信息登记表电商运营平台
  • 怎样申请网站域名
  • 如何用模板做网站谷歌seo网络公司
  • 溧阳网站制作app推广渠道
  • 怎么在网站上做推北京百度seo排名公司
  • 如何做网站的主页网站seo优化服务
  • 58同城二手房百度seo排名点击
  • 做淘宝一样的网站培训机构是干什么的
  • 海外网络推广方案谷歌seo排名公司
  • 网站和管理系统的区别兰蔻搜索引擎营销案例
  • 阿里巴巴官网下载app朝阳seo
  • 怎么查一个网站是谁做的深圳百度关键词
  • 品牌vi设计一般多少钱seo博客大全