中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Element-ui tree組件自定義節點的示例分析

發布時間:2021-07-27 14:13:32 來源:億速云 閱讀:219 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關Element-ui tree組件自定義節點的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

工作上使用到element-ui tree 組件,主要功能是要實現節點拖拽和置頂,通過自定義內容方法(render-content)渲染樹代碼如下~

<template>
 <div class="sortDiv">
  <el-tree :data="sortData" draggable node-key="id" ref="sortTree" default-expand-all :expand-on-click-node="false" :render-content="renderContent" :allow-drop="allowDrop">
  </el-tree>
  <el-button @click="getData">獲取數據</el-button>
 </div>
</template>
<script>
export default {
 name: 'Sort',
 data() {
  return {
   sortData: [
    {
     id: 1,
     label: '一級 1',
     checkItem: true,
     children: [
      {
       id: 4,
       label: '二級 1-1',
       checkItem: false
      },
      {
       id: 9,
       label: '二級 1-2',
       checkItem: false
      },
      {
       id: 10,
       label: '二級 1-3',
       checkItem: false
      }
     ]
    },
    {
     id: 2,
     label: '一級 2',
     checkItem: true,
     children: [
      {
       id: 5,
       label: '二級 2-1',
       checkItem: true
      },
      {
       id: 6,
       label: '二級 2-2',
       checkItem: true
      }
     ]
    },
    {
     id: 3,
     label: '一級 3',
     checkItem: true,
     children: [
      {
       id: 7,
       label: '二級 3-1',
       checkItem: true
      },
      {
       id: 8,
       label: '二級 3-2',
       checkItem: false
      }
     ]
    }
   ]
  };
 },
 methods: {
  // 是否允許拖拽
  allowDrop (draggingNode, dropNode, type) {
   if (draggingNode.parent === dropNode.parent) {
    return type !== 'inner'
   }
   else return false
  },
  //獲取數據
  getData () {
   let result = this.$refs['sortTree'].data;
   let sortRulesMaps = [];
   result.forEach((element, index) => {
    let item = null;
    if (element.checkItem) {
     if (element.children && element.children.length > 0) {
      item = {
       orderIndex: index,
       sortField: element.label,
       rule: ['OTHERS']
      };
      element.children.forEach(i => {
       if (i.checkItem) {
        item.rule.push(i.label);
       }
      });
      item.rule = item.rule.join('_');
     }
    }
    item && sortRulesMaps.push(item);
   });
  },
  //同級置頂功能
  toTop(node, data) {
    let c = Object.assign({}, data);
    if (node.parent.level === 0) {
     this.sortData.unshift(c)
    } else {
     node.parent.data.children.unshift(c);
    }
    this.$refs['sortTree'].remove(data.id);
  },
  changeNode(r, node, data) {
   data.checkItem = r;
  },
  //自定義內容
  renderContent(h, { node, data }) {
   return (
    <span class="custom-tree-node">
     <span>{data.label}</span>
     <span>
      <el-checkbox
       v-model={data.checkItem}
       checked={data.checkItem}
       on-change={r => this.changeNode(r, node, data)}
      />
      <el-button
       size="mini"
       type="text"
       on-click={() => this.toTop(node, data)}
       
      >
       <i class="fa fa-arrow-up">置頂</i>
      </el-button>
     </span>
    </span>
   );
  }
 }
};
</script>
<style lang="scss">
.sortDiv {
 .el-icon-caret-right:before {
  content: '\E604';
 }
}
.custom-tree-node {
 flex: 1;
 display: flex;
 align-items: center;
 justify-content: space-between;
 font-size: 14px;
 padding-right: 8px;
}
</style>

補充:下面看下使用element的自定義tree組件的實例代碼

在使用elemnet-ui時,需要自定義tree的一些元素,采用 :render-content屬性來進行渲染這些元素,但是官網給的例子有一點小坑,

 renderContent:function(createElement, { node, data, store }) {
        var self = this;
        return createElement('span', [
          createElement('span', node.label),
          createElement('span', {attrs:{
            style:"float: right; margin-right: 200px"
          }},[
            createElement('el-button',{attrs:{
              size:"mini"
            },on:{
              click:function() {
                console.info("點擊了節點" + data.id + "的添加按鈕");
                store.append({ id: self.baseId++, label: 'testtest', children: [] }, data);
              }
            }},"添加"),
            createElement('el-button',{attrs:{
              size:"mini"
            },on:{
              click:function() {
                console.info("點擊了節點" + data.id + "的刪除按鈕");
                store.remove(data);
              }
            }},"刪除"),
          ]),
        ]);
      }

關于“Element-ui tree組件自定義節點的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

綦江县| 镇原县| 信阳市| 天水市| 留坝县| 北宁市| 马边| 泸西县| 镇远县| 怀仁县| 宁陵县| 若羌县| 五原县| 三明市| 新田县| 黔江区| 衡东县| 中山市| 休宁县| 瑞昌市| 济南市| 莆田市| 额尔古纳市| 威海市| 平陆县| 蓝田县| 孝昌县| 林口县| 保亭| 四会市| 乌海市| 定结县| 德清县| 贺兰县| 巴彦淖尔市| 肥乡县| 翁源县| 马尔康县| 大安市| 金堂县| 图木舒克市|