In the element-ui tree control, the parent node is set to be semi-selected after getting data asynchronously.

In the

element-ui tree control, the values of some child nodes in a node are taken, and the id values of both the child node and the parent node are needed in the background. I use getHalfChecked to get the id value of the parent node in the semi-selected state, but when I reverse render the control, all the child nodes in the parent node are selected by default. After checking the document and issue, for a long time, the interface for dynamically setting the semi-selected state is not found. The code is as follows:

clipboard.png

clipboard.png
:

clipboard.png

Mar.18,2022

I don't know if it is the result you want. The selected data returned by the backend contains both parent ID and subset ID,. First, the parent ID, is recursively extracted, then the parent ID, is deleted and finally rendered.
Preview: https://jsfiddle.net/gka8xtm2/


Hello, I am also using this component, but when I edit the backfill, as long as the parent is selected, the following will be selected. I don't know why. Could you take a look at it for me? Thank you

 getHovePer(row){
            let data = {
                id: row.id
            }
            hovePermiss(data).then( res => {
                if(res.info.ok == true){
                  let actionData = res.data;
                  // 
                  let selectArr = [];
                  for(var i in actionData){
                      let oneObj = {};
                      actionData[i].id = actionData[i].number;
                      if(actionData[i].status == 'on'){
                          oneObj.id = actionData[i].number;
                          oneObj.name = actionData[i].name;
                          selectArr.push(actionData[i].number);
                          actionData[i].switchStatus = true;
                      } else {
                          actionData[i].switchStatus = false;
                      }
                      //    
                      if(actionData[i].sub_rule.length > 0){
                          let twoArr = actionData[i].sub_rule;
                          for(var j in twoArr){
                            let twoObj = {};
                            twoArr[j].id = twoArr[j].number;
                            if(twoArr[j].status == 'on'){
                                twoObj.id = twoArr[j].number;
                                twoObj.name = twoArr[j].name;
                                selectArr.push(twoArr[j].number);
                                twoArr[j].switchStatus = true;
                            } else {
                                twoArr[j].switchStatus = false;
                            }
                            //  
                            if(twoArr[j].sub_rule.length > 0){
                                let threeArr = twoArr[j].sub_rule;
                                for(var k in threeArr){
                                  let threeObj = {};
                                  threeArr[k].id = threeArr[k].number;
                                  if(threeArr[k].status == 'on'){
                                       threeObj.id = threeArr[k].number;
                                       threeObj.name = threeArr[k].name;
                                       selectArr.push(threeArr[k].number);
                                       threeArr[k].switchStatus = true;
                                  } else {
                                       threeArr[k].switchStatus = false;
                                  } 
                                  //    
                                  if(threeArr[k].sub_rule.length > 0){
                                      let fourArr = threeArr[k].sub_rule;
                                      for(var l in fourArr){
                                          let fourObj = {};
                                        fourArr[l].id = fourArr[l].number;
                                        if(fourArr[l].status == 'on'){
                                            fourObj.id = fourArr[l].number;
                                            fourObj.name = fourArr[l].name;
                                            selectArr.push(fourArr[l].number);
                                            fourArr[l].switchStatus = true;
                                        } else {
                                            fourArr[l].switchStatus = false;
                                        }
                                        //  
                                        if(fourArr[l].sub_rule.length > 0){
                                           let fiveArr = fourArr[l].sub_rule;
                                           for(var f in fiveArr){
                                               let fiveObj = {};
                                               fiveArr[f].id = fiveArr[f].number;
                                               if(fiveArr[f].status == 'on'){
                                                   fiveObj.id = fiveArr[f].number;
                                                   fiveObj.name = fiveArr[f].name;
                                                   selectArr.push(fiveArr[f].number);
                                                   fiveArr[f].switchStatus = true;
                                               }else { 
                                                   fiveArr[f].switchStatus = false;
                                               }
                                           }
                                        }  
                                      }
                                  } 
                               }
                            }
                          }
                      }
                  }
                  console.log('----selectArr---',selectArr);
                  
                  this.$refs.tree.setCheckedKeys(selectArr);
                  this.hovePermissData = res.data;
                  console.log('----this.hovePermissData---',this.hovePermissData);
                }
            })
        },
MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1e3f597-43fb7.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1e3f597-43fb7.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?