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

学做网站论坛会员邯郸seo

学做网站论坛会员,邯郸seo,做导师一般去什么网站找素材,南宁网站建设哪家安装和使用 见官方文档:https://github.com/Akryum/vue-virtual-scroller/tree/master/packages/vue-virtual-scroller 如何获取子组件的实例 背景 本来正常情况下,要获取v-for渲染的子组件的实例,通过ref绑定即可获取到数组,并…

安装和使用

见官方文档:https://github.com/Akryum/vue-virtual-scroller/tree/master/packages/vue-virtual-scroller

如何获取子组件的实例

  1. 背景

    本来正常情况下,要获取v-for渲染的子组件的实例,通过ref绑定即可获取到数组,并通过index即可定位到vue实例

    <template><RecycleScrollerclass="scroller":items="list":item-size="32"key-field="id"v-slot="{ item }"><Info ref="info">{{ item.name }}</Info></RecycleScroller>
    </template>
    

    但是由于这里使用的是虚拟列表,info.value打印出来的结果只是渲染出来的第一个实例

  2. 解决方案

    发现,通过为每一个组件绑定不同的ref,通过这多个ref能够获取到每一个实例,比如info0.valueinfo1.value

    那么,就只需要根据list动态的创建多个ref,优化方案,多个ref放到数组中,通过index访问

    <RecycleScrollerclass="scroller"ref="scroller":items="arr":item-size="145":buffer="400"key-field="itemCode"v-slot="{ item, index }"
    ><OutInfo:ref="outInfoRefs[index]"/>
    </RecycleScroller>//子组件的实例(这里通过数组来进行存储,每一个实例存储一个)
    const outInfoRefs: any = [];
    arr.value.forEach(item => outInfoRefs.push(ref()));
    

    这样打印出来的outInfoRefs将会是多个ref实例

    注意:这里打印出来的并没有所有的,只有视口上展示出来的加上不可见的预加载的几个

    比如是这样的:[null, null, null, ref(), ref(), ref(), ref(), null, null, null]

如何保存不在视口区域内的子组件的状态

  1. 背景

    如果你在子组件的onMounted中输出日志的话,会发现,只有一开始加载的几个元素会输出,后面为了提高效率只是重复渲染这已经加载的几个元素而已

    那么问题来了:实际上不同的子组件里面的状态是不一样的,传递进去的props是会获取到的,但是自己维护的是不变的

    比如每个子组件有一个input,你在第一个输入了一个hello,假定你重复渲染的子组件是5个,那么在第6个子组件渲染的时候,你会惊奇的发现他已经变成了hello,这显然不是我们需要的结果

  2. 解决方案

    前面说过,props是会正常获取到的,那么通过watchprops的变化,比如传递一个index

    然后在这个watch中根据需要,去初始化组件状态,那么就可以实现

    watch(() => props.index,(newVal) => {// 由于使用的是虚拟滚动,每个子元素是复用的,css样式会保留,通过监听index的变化,来达到重新渲染每个子元素的效果if (props.focusIndex === newVal) {// 如果当前子元素是选中的,那么需要进行一些操作} else {// 如果当前子元素不是选中的,那么需要进行另一些操作doBlur(1);delColor();editIsDisabled();}}
    );
    
  3. 另一个问题(赋初值,保存变化值)

    假定第一个元素的input已经赋值了hello,如果通过上面的代码的话,那么第6个已经正常置空了

    但是回去到第1个时候,会发现也被置空了,但是并不能通过props获取到刚才的改变,因为没有保存

    因为子元素无法保存,但是对应的数据是可以保存的,比如添加一个属性tempValue,在change的时候,通过props进行改变,然后在watch的时候赋值上去,这样是可行的

http://www.dinnco.com/news/20319.html

相关文章:

  • 注册公司好还是注册公司好关键词优化心得
  • 那家建设网站p2p公司最好?合肥百度推广公司哪家好
  • 汕头网站开发上海seo网络优化
  • 做公众号的公司是什么公司网站seo关键词优化排名
  • 无锡市建设局网站网上培训课程平台
  • 做网站的不肯给ftp推广引流吸引人的标题
  • 政府网站建设预算网站营销方案
  • 做日用品有什么网站免费宣传网站
  • 自己做的网站怎么维护网页免费制作网站
  • ip开源网站fpga可以做点什么用推广小程序
  • 网站怎么做百度能搜到html网页完整代码作业
  • 朝阳网站网络推广的方式有哪些
  • 网络公司网站建广告营销推广方案
  • 怎样做克隆网站视频营销案例
  • 网站公司做的网站经常打不开外贸网站搭建推广
  • WORDPRESS摘要无效网站关键词优化方案
  • 类似链家网站建设方案谷歌引擎搜索入口
  • 网站注册备案之后怎么做湖南专业seo优化
  • 免费建立手机网站吗百度风云榜小说排行榜
  • 用别人的公司名字做网站公司广告推广方案
  • 把自己做的网页发布到网站seo平台代理
  • html代码颜色seo是做什么工作内容
  • 网站建设设计制作培训seo优化的方法
  • 网站的域名和密码学电子商务出来能干嘛
  • 厦门开发网站公司外链发布工具
  • 万户网站建设外链火
  • 阿里云服务器做盗版视频网站吗网站建设与管理属于什么专业
  • 唐山网站建设哪家优惠搜索引擎的使用方法和技巧
  • 小面网站建设宁波网站推广专业服务
  • 织梦做的网站别人提交给我留的言我去哪里看全网营销系统是干什么的