• vue+element 树形结构 改成懒加载模式(原理element有),这里只做个人理解笔记


    1

    找到属性标签添加 lazy 和 :load="loadNode"    这两个属性

    2

    引入树形接口,并和后端约定好传值,(拿我的举例 

    第一次获取全部父级默认第一次传参数:{ parentId : 0},可获取全部父级

    第二次通过点击的子级把子级id传进去,这一步就用到了:load="loadNode"  这个方法,完全自动把子级放到对应的父级上去) 

    第三和后端沟通好每一层里给你带leaf:true(是最后一层)leaf:false(不是最后一层)     我这里用的是树状表格的接口  所以在方法里循环转换了一下值  但是结果和原理不变
    [这个值可以控制树🌲形结构前边的"三角"或"+"显示不显示的],就是可以看到是不是最后一级,还能不能打开

    import { treeselect } from '@/api/system/123/456/dept'     //引入的接口

    3

    data里添加对应值

    下边是代码:懒得写的可以复制字段值

    1. // 部门树选项
    2. deptOptions: undefined,
    3. defaultProps: {
    4. children: 'children',
    5. label: 'label',
    6. isLeaf: 'leaf'
    7. },

    先获取全部父级 并循环付给对应值 (如果能和后端商量好字段可能不用前端forEach循环赋值)

    1. /** 查询部门下拉树结构 */
    2. getTreeselect() {
    3. treeselect({parentId:0}).then((response) => {
    4. this.deptOptions = response.data
    5. this.deptOptions.forEach(item=>{
    6. item.leaf = !item.hasChildren
    7. item.label = item.deptName
    8. })
    9. })
    10. },

       提醒  在这里别忘了把方法夹到created()里

    1. created() {
    2. this.getTreeselect()
    3. },

    5

    懒加载方法node.level === 0的时候添加获取父级的接口,node.level === 1的时候把子级ID传进去

    resolve(response.data) 就自动把获取的子级放到对应的位置了

    1. loadNode(node, resolve) {
    2. if (node.level === 0) {
    3. treeselect({ parentId : 0}).then((response) => {
    4. response.data.map(item=>{
    5. item.leaf = !item.hasChildren
    6. item.label = item.deptName
    7. })
    8. resolve(response.data);
    9. })
    10. }
    11. if (node.level >= 1){
    12. setTimeout(() => {
    13. treeselect({ parentId : node.data.deptId}).then((response) => {
    14. response.data.map(item=>{
    15. item.leaf = !item.hasChildren
    16. item.label = item.deptName
    17. })
    18. resolve(response.data);
    19. })
    20. }, 500);
    21. };
    22. },

    赠送内容  添加搜索 和后端约定好不传parentId只传参数  返回对应值

    1. v-model="deptName"
    2. :placeholder="请输入参数"
    3. clearable
    4. size="mini"
    5. style="margin-bottom: 20px"
    6. >

    然后watch监听这个参数

    1. watch: {
    2. // 根据名称筛选部门树
    3. deptName(val) {
    4. this.deptOptions =[]
    5. if(val){
    6. var objquery = {
    7. deptName : val,
    8. }
    9. treeselect(objquery).then((response) => {
    10. response.data.map(item=>{
    11. item.leaf = !item.hasChildren
    12. item.label = item.deptName
    13. })
    14. this.deptOptions = response.data
    15. this.$refs.tree.filter(response.data[0].deptName)
    16. })
    17. }else{
    18. this.getTreeselect()
    19. }
    20. },

  • 相关阅读:
    NFS服务详解
    【vue2+onlyoffice】基础预览demo运行+问题解决
    Navicat设置数据库权限
    已解决ModuleNotFoundError: No module named ‘PIL‘
    MySQL介绍
    @MapperScan 和 @Mapper 源码走读
    C# 之委托和事件
    【图形学】26 透明效果基础
    P4 开发实践 — NG-SDN Tutorial — Exercise 6: Segment Routing v6 (SRv6)
    面了个阿里拿38k出来的,让我见识到了基础顶端
  • 原文地址:https://blog.csdn.net/xu_duo_i/article/details/138184133