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

品牌建设的三大理论杭州优化关键词

品牌建设的三大理论,杭州优化关键词,什么是独立站?,wordpress信用卡支付宝在项目中做需求,遇到一个比较棘手的问题,el-tree懒加载在包含下级的时候,需要做回显,将选中的数据再次勾选上,在处理这个需求的时候有两点是比较困难的: el-tree是懒加载的,包含下级需要一层一…

在项目中做需求,遇到一个比较棘手的问题,el-tree懒加载在包含下级的时候,需要做回显,将选中的数据再次勾选上,在处理这个需求的时候有两点是比较困难的:

  1. el-tree是懒加载的,包含下级需要一层一层展开,每次都会有一个请求,而我们的请求有时候很慢(每次resolve数据的时候都要请求一个数据),每次请求都会产生loading,loading过多加载时间过长,这个需要考虑。
  2. el-tree由于是懒加载而且是包含下级的,我们这边初次的方案是通过default-checked-keysdefault-expanded-keys属性进行回显,发现总是会多展开一层

这是模拟的数据

loadNode(node, resolve) {// orgPower是一个权限标识if (this.orgPower) {new Promise((_resolve) =>_resolve({ name: "总行", orgRefNo: "01" })).then((res) => {this.orgPower = false;return resolve([res]);});} else {new Promise((_resolve) =>_resolve(this.handleNodeData(node.data.orgRefNo))).then((res) => {return resolve(res);});}},handleNodeData(orgRefNo) {const data = [];for (let i = 0; i < new Array(5).length; i++) {data.push({name: `测试${orgRefNo}0${i + 1}`,orgRefNo: `${orgRefNo}0${i + 1}`,});}return data;},

el-tree的属性配置:

:props="{label:'name'}"
:load="loadNode"
highlight-current
lazy
show-checkbox
:current-node-key="currentNodeKey"
:default-expanded-keys="defaultExpandedKey"
:default-checked-keys="treeCheckKeyList"
node-key="orgRefno"// treeCheckKeyList => ['01', '0101', '0102', '0103', '0104', '0105']

这是产生出来的效果
在这里插入图片描述

比如说我们默认回显的是总行的值,但是因为是包含下级的,所以总行下一级的数据会全部会被回显。(treeCheckKeyList为 ['01', '0101', '0102', '0103', '0104', '0105'])这里我们做的是下一级的数据会被回显,不是下层好几级的数据都会回显,这是因为由于数据是懒加载的,下级,下下级,下下下级。。。的数据是未知的,所以只能做到其下一级。
这是我们的初始方案:

  1. 后端提供一个查询父级的接口,这个接口需要把选中数据的值传给后端,然后查询出来这些选中数据的父级,父父级,父父父级。。。直到找到最顶层级别,返回给前端。
// 这里模拟的选中的数据是总行及下一级,选中的数据对应的id是 ['01', '0101', '0102', '0103', '0104', '0105']
// '0101', '0102', '0103', '0104', '0105' 上级是总行(01),总行是最顶级,所以最终所有的上级是 01
// 同时后端还会把所有的选中的数据返回(这里会导致后面的问题),所以总共返回的是['01', '0101', '0102', '0103', '0104', '0105']
// 如果模拟选中的数据是测试0101(对应的id是0101),包含下级,总共选中的数据是 010101 010102 010103 010104 010105
// 返回的数据是 01(0101的上级) 0101(010101 010102 010103 010104 010105的上级) 010101 010102 010103 010104 010105
queryUpOrgList() {this.$apiHttp('queryUpOrgList', { listData: ['01', '0101', '0102', '0103', '0104', '0105']}).then(res => {// res.data 是['01', '0101', '0102', '0103', '0104', '0105']this.defaultExpandedKey = res.data})
},
  1. 把后端返回的数据,赋值defaultExpandedKey,把这些数据默认展开,即可自动勾选到下一级
    看一下最终的效果
    在这里插入图片描述
    问题是把第三层级的也选上了,主要原因是查询上级接口的返回数据把选中的数据也返回了
    那如果把给后端传递的数据过滤一下呢?是不是就可以了。
    不可以,过滤数据比较麻烦,不知道应该过滤哪些条数据。选中的数据分布可能比较混乱,分布在各个层级。
    而且,这种还是会请求很多次接口,
new Promise((_resolve) =>_resolve(this.handleNodeData(node.data.orgRefNo))).then((res) => {return resolve(res);
);

这里的接口会被调用多次。
后来,经过分析主要实现的难点在

  • 包含下级的时候,无法做到真正的最后一级不展开(比如这里指的是0101,0102,0103,0104,0105数据不展开,一旦展开就会自动默认把下级勾选上)
  • 数据加载过多的话,需要请求多次(有时候数据量很大,一次性勾选很多很多条数据,回显请求的接口过多,影响使用体验)

基于上面的难点和体验,又换了一套方案实现:就是不会主动去触发哪些节点展开,也就不会调用查询父级的接口queryUpOrgList,进而不会多次执行resolve,进行下级数据查询,而是给用户一个标识----对于全选,半选的数据,将全选,半选的标识再去默认赋上,这样让用户一层一层的去点击。
效果如下:
在这里插入图片描述
首次只加载初始化数据,全选,半选给出一个标识,让用户知道数据在哪些层级,手动去进行点击。因为此次数据主要是用作回显使用,所以我们需要给这样一个变量去处理回显数据

nodesMap: {"01": { checked: false, indeterminate: true, name: "总行" },"0101": { checked: false, indeterminate: true, name: "测试0101" },"0102": { checked: true, name: "测试0102" },"010101": { checked: true, indeterminate: true, name: "测试010101" },
},

indeterminate用作半选的回显,checked用作全选的回显。

http://www.rdtb.cn/news/14184.html

相关文章:

  • 2017优惠券网站怎么做广州优化公司哪家好
  • 建设国外网站引流吗可以推广的软件有哪些
  • 网站建设推广和网络推广爱站网站长百度查询权重
  • 微信网站制作系统百度爱采购推广怎么入驻
  • 建设网贷网站怎么提交百度收录
  • 网站显示手机中病毒要按要求做最近一周的新闻热点事件
  • 网站建设教程所需文字网络推广网站有哪些
  • 优秀广告案例分析苏州手机关键词优化
  • wordpress菜单锚点seo诊断书案例
  • 做印刷网站公司简介东莞seo优化排名推广
  • 成都网站改版优化电脑突然多了windows优化大师
  • 德国的网站域名百度搜索指数1000是什么
  • 切实加强政府网站建设与管理网络推广外包想手机蛙软件
  • 经典设计产品网站seo批量查询工具
  • 天津b2b网站建设公司哪家好优云优客百度推广效果怎么样
  • 电商网站的建设的主要目的他达拉非片多少钱一盒
  • 石岩做网站武汉seo广告推广
  • 嘉兴备案网站牛排seo
  • 网站的字体投广告哪个平台好
  • 哪个网站做新加坡劳务比较好的北京网站seo设计
  • 做赌石网站客服的经验网站优化排名操作
  • 新手做网页做那个网站简单培训机构需要什么资质
  • 关于网站制作报价windows优化大师官方
  • 百度快照比网站上线时间早企业百度推广怎么收费
  • 东莞长安网站设计武汉seo网站优化排名
  • 网站建设 面试题成都网站seo设计
  • 重庆茶叶网站建设线上营销策划方案
  • 软件开发网站建设google广告投放
  • 郑州建站优化写软文赚钱的平台都有哪些
  • 先做个在线电影网站该怎么做免费二级域名分发