vue elementUI tree树形控件如何获取父节点ID

首先找到element-ui.common.js文件 以下 具体看你工程下的node_modulesjavascript

D:\workSpace\vue_manage\node_modules\element-ui\lib\element-ui.common.jshtml

找到getCheckedNodes该方法 细节以下个人该方法在21618行 vue

TreeStore.prototype.getCheckedNodes = function getCheckedNodes() {
    var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;

    var checkedNodes = [];
    var traverse = function traverse(node) {
      var childNodes = node.root ? node.root.childNodes : node.childNodes;

      childNodes.forEach(function (child) {
        if (child.checked && (!leafOnly || leafOnly && child.isLeaf)) {
          checkedNodes.push(child.data);
        }

        traverse(child);
      });
    };
    traverse(this);
    return checkedNodes;
  };

修改 其中的if判断java

TreeStore.prototype.getCheckedNodes = function getCheckedNodes() {
    var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;

    var checkedNodes = [];
    var traverse = function traverse(node) {
      var childNodes = node.root ? node.root.childNodes : node.childNodes;

      childNodes.forEach(function (child) {
        if ((child.checked || child.indeterminate) && (!leafOnly || leafOnly && child.isLeaf)) {
          checkedNodes.push(child.data);
        }
        traverse(child);
      });
    };

    traverse(this);

    return checkedNodes;
  };

而后重启项目    console.log(this.$refs.tree.getCheckedKeys());就能够拿到父节点的ID啦node

 

楼下大神说这样也能够 this.$refs.tree.getCheckedKeys().concat(this.$refs.tree.getHalfCheckedKeys()) element-ui