真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

xmlplus如何實(shí)現(xiàn)Tree組件-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)xmlplus如何實(shí)現(xiàn)Tree組件的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

超過十余年行業(yè)經(jīng)驗(yàn),技術(shù)領(lǐng)先,服務(wù)至上的經(jīng)營模式,全靠網(wǎng)絡(luò)和口碑獲得客戶,為自己降低成本,也就是為客戶降低成本。到目前業(yè)務(wù)范圍包括了:網(wǎng)站設(shè)計制作、做網(wǎng)站,成都網(wǎng)站推廣,成都網(wǎng)站優(yōu)化,整體網(wǎng)絡(luò)托管,成都小程序開發(fā),微信開發(fā),App定制開發(fā),同時也可以讓客戶的網(wǎng)站和網(wǎng)絡(luò)營銷和我們一樣獲得訂單和生意!

樹形組件是一種具有層級結(jié)構(gòu)的組件,廣泛應(yīng)用于各種場景。

xmlplus如何實(shí)現(xiàn)Tree組件

數(shù)據(jù)源

樹形組件的數(shù)據(jù)源可以是 JSON 格式的數(shù)據(jù)對象,也可以是具有 XML 結(jié)構(gòu)的數(shù)據(jù)或者是其它的具有層級結(jié)構(gòu)的數(shù)據(jù)。本章將采用具有如下 JSON 格式的數(shù)據(jù)對象。

var data = {
 name: 'My Tree',
 children: [
 { name: 'hello' },
 { name: 'world' },
 {
  name: 'child folder',
  children: [
  { name: 'alice' }
  ]
 }
 ]
};

上述數(shù)據(jù)源中,name 值會作為樹結(jié)點(diǎn)的名稱顯示,含 children 的數(shù)組代表節(jié)點(diǎn)的子級。

遞歸結(jié)構(gòu)的設(shè)計

由 HTML 中的列表元素 ul 以及 li 組合而成對象具有天然的樹形結(jié)構(gòu),我們不妨采用它們作為構(gòu)建樹形組件的基本元素。樹形組件的最外層必然是一個 ul 元素,所以我們可以暫時定義樹形組件如下:

Tree: {
 xml: `
   
   `
}

這里的未定義的組件 Item 是一個需要遞歸定義的子項(xiàng)組件,它會根據(jù)提供的數(shù)據(jù)遞歸地生成子孫對象。下面是一種可能的設(shè)計:

Item: {
 xml: `
   
    
   
       `,  map: { defer: "entries" } }

注意,上面的 neme 對象是用于顯示 name 屬性的。expand 對象用于展開或者關(guān)閉子級對象 entries。子級對象 entries 被設(shè)置為需要延遲實(shí)例化,只有當(dāng)用戶點(diǎn)擊 expand 對象展開子級時,該對象才會實(shí)例化。

數(shù)據(jù)的加載與渲染

如上一節(jié)所述,我們設(shè)定了子級對象 entries 需要延遲實(shí)例化。所以,在給子項(xiàng) Item 提供的數(shù)據(jù)設(shè)置接口不應(yīng)該立馬對 entries 實(shí)例化。下面我們先給出數(shù)據(jù)接口函數(shù)。

Item: {
 // css, xml, map 項(xiàng)同上
 fun: function (sys, items, opts) {
  var data;
  function val(value) {
   data = value;
   sys.neme.text(data.name);
   data.children && data.children.length && sys.expand.show().text(" [+]");
  }
  return { val: val };
 }
}

該接口函數(shù) val 只是設(shè)置了當(dāng)前節(jié)點(diǎn)相關(guān)的內(nèi)容。下面我們來偵聽 expand 對象的點(diǎn)擊事件,并適時地完成組件對象 entries 的實(shí)例化。

Item: {
 // css, xml, map 項(xiàng)同上
 fun: function (sys, items, opts) {
  var data, open;
  sys.expand.on("click", function () {
   open = !open;
   sys.expand.text(open ? " [-]" : " [+]");
   open ? (sys.entries.show() && load()) : sys.entries.hide();
  });
  function load() {
   if ( sys.entries.children().length == 0 )
    for ( var item of data.children )
    sys.add.before("Item").value().val(item);
  }
  function val(value) {
   data = value;
   sys.neme.text(data.name);
   data.children && data.children.length && sys.expand.show().text(" [+]");
  }
  return { val: val };
 }
}

上述代碼中包含一個 open 參數(shù),該參數(shù)記錄了當(dāng)前節(jié)點(diǎn)的是否處于展開狀態(tài)以供相關(guān)的偵聽器使用。

動態(tài)添加節(jié)點(diǎn)

現(xiàn)在我們對上述組件進(jìn)行一個小的擴(kuò)展,使得它支持動態(tài)添加樹節(jié)點(diǎn)的功能。首先,我們在對象 entries 的子級添加一個觸發(fā)按鈕,并命名為 add。

Item: {
 xml: "
   
    
   
        +        ",  map: { defer: "entries" } }

其次,需要偵聽 add 對象的點(diǎn)擊事件,在偵聽器中完成對象的添加。

Item: {
 // css, xml, map 項(xiàng)同前
 fun: function (sys, items, opts) {
  var data, open;
  sys.item.on("click", "http://*[@id='add']", function () {
   var stuff = {name: 'new stuff'};
   data.children.push(stuff);
   sys.add.before("Item").value().val(stuff);
  });
  // 其余代碼同前
 }
}

這里需要注意,對 add 對象的偵聽不能采取直接式的偵聽:sys.add.on("click",...),而應(yīng)該使用代理的方式,否則會報錯。因?yàn)槠涓讣墝儆谘舆t實(shí)例化的組件,在 entries 對象未實(shí)例化之間,add 對象并不可見。

完整的樹形組件

綜合以上的內(nèi)容,現(xiàn)在給出一個完整版本的樹形組件:

Tree: {
 css: `#tree { font-family: Menlo, Consolas, monospace; color: #444; }
   #tree, #tree ul { padding-left: 1em; line-height: 1.5em; list-style-type: dot; }`,
 xml: `
   
   `,
 fun: function (sys, items, opts) {
  return items.item;
 }
},
Item: {
 css: "#item { cursor: pointer; }",
 xml: `
   
    
   
        +        `,  map: { defer: "entries" },  fun: function (sys, items, opts) {   var data, open;   sys.item.on("click", "http://*[@id='add']", function () {    var stuff = {name: 'new stuff'};    data.children.push(stuff);    sys.add.before("Item").value().val(stuff);   });   sys.expand.on("click", function () {    open = !open;    sys.expand.text(open ? " [-]" : " [+]");    open ? (sys.entries.show() && load()) : sys.entries.hide();   });   function load() {    if ( sys.entries.children().length == 1 )     for ( var item of data.children )     sys.add.before("Item").value().val(item);   }   function val(value) {    data = value;    sys.neme.text(data.name);    data.children && data.children.length && sys.expand.show().text(" [+]");   }   return { val: val };  } }

在實(shí)際應(yīng)用中的樹形組件會比這里的功能更豐富些,你可以在上述代碼的基礎(chǔ)上進(jìn)一步的改進(jìn),比如添加些 ICON 圖標(biāo)、讓子項(xiàng)成為可拖動的等等。但在改進(jìn)過程中盡量避免代碼的復(fù)雜化,適當(dāng)?shù)貏冸x些代碼出來封裝成組件是非常有必要的。

感謝各位的閱讀!關(guān)于“xmlplus如何實(shí)現(xiàn)Tree組件”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


本文名稱:xmlplus如何實(shí)現(xiàn)Tree組件-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://weahome.cn/article/ijsep.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部