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

這篇文章主要介紹了xmlplus中如何實(shí)現(xiàn)選項(xiàng)卡組件,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),安丘企業(yè)網(wǎng)站建設(shè),安丘品牌網(wǎng)站建設(shè),網(wǎng)站定制,安丘網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,安丘網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

示意圖:

xmlplus中如何實(shí)現(xiàn)選項(xiàng)卡組件

選項(xiàng)卡組成

在具體實(shí)現(xiàn)之前,想像一下目標(biāo)組件是如何使用的,對(duì)于設(shè)計(jì)會(huì)有莫大的幫助。通過觀察,可以將選項(xiàng)卡組件分為容器部分和子項(xiàng)部分,正如下面的 XML 結(jié)構(gòu)所展示的。

<Tabbar id="tabbar">
  <TabItem id="home" label="首頁(yè)"/>
  <TabItem id="setting" label="設(shè)置"/>
  <TabItem id="logs" label="日志"/>
  <TabItem id="about" label="關(guān)于"/>
</Tabbar>

現(xiàn)在我們把目光切換到選項(xiàng)卡組件的子項(xiàng)部分,來看看子項(xiàng)部分是如何分解的。通過示意圖,你可以發(fā)現(xiàn)子項(xiàng)部分可以分解為子項(xiàng)容器以及包含一個(gè)圖標(biāo)和一個(gè)文本的子級(jí)部分。

<a id="tabitem">
  <Icon id="icon"/>
  <span id="label">首頁(yè)</span>
</a>

所以,現(xiàn)在我們的目標(biāo)已經(jīng)很明確了,主要設(shè)計(jì)三個(gè)組件:圖標(biāo)組件 Icon、選項(xiàng)卡組件的子項(xiàng) TabItem 以及選項(xiàng)卡組件的容器 Tabbar。

結(jié)構(gòu)圖

由于該組件比較簡(jiǎn)單,所以可以將三種子組件放置在同一層級(jí)。但請(qǐng)注意,我們還有四個(gè)圖標(biāo)組件,可以創(chuàng)建一個(gè)子級(jí)用于容納它們。下面給出我們的組件結(jié)構(gòu)圖:

Tabbar/
├── Tabbar
├── TabItem
└── Icon/
     ├── About
     ├── Home
     ├── Logs
     └── Setting

圖標(biāo)的實(shí)現(xiàn)

我們從最簡(jiǎn)單的開始,先看四個(gè)圖標(biāo)組件,圖標(biāo)組件主要通過封裝 SVG 文本來實(shí)現(xiàn),由于圖標(biāo)文本較長(zhǎng),所以這里僅截取每個(gè)圖標(biāo)文本的一段。

About: {
  xml: `<svg width="48" height="48" viewBox="0 0 1024 1024">
        <path d="M507.577907 23.272727C240.142852..."/>
     </svg>`
},
Home: {
  xml: `<svg width="48" height="48" viewBox="0 0 1024 1024">
        <path d="M949.082218 519.343245 508.704442..."/>
     </svg>`
},
Logs: {
  xml: `<svg width="48" height="48" viewBox="0 0 1024 1024">
        <path d="M576 125.344l32 0 0 64-32 0 0-64Z..."/>
     </svg>`
},
Setting: {
  xml: `<svg width="48" height="48" viewBox="0 0 1024 1024">
        <path d="M512 336.664c-96.68 0-175.336 78...."/>
     </svg>`
}

請(qǐng)注意,這些圖標(biāo)位于虛擬目錄 /icon 之下,也就是你要像下面這樣導(dǎo)入:

xmlplus("ui", function (xp, $_, t) {
  $_().imports({Tabbar: {... }, TabItem: {...}});

  $_("icon").imports({--這里包含了四個(gè)圖標(biāo)組件--});
});

下面來實(shí)現(xiàn)圖標(biāo)組件 Icon,這里的圖標(biāo)組件與上面是不同的,它會(huì)根據(jù)輸入的圖標(biāo)類型實(shí)例化不同的圖標(biāo)。這樣設(shè)計(jì)可以復(fù)用部分相同的代碼,避免冗余。

Icon: {
  css: "#icon { width: 1.5em; height: 1.5em; display: inline-block; }",
  opt: { icon: "about" },
  xml: `<span id="icon"/>`,
  fun: function (sys, items, opts) {
    sys.icon.replace("icon/" + opts.icon).addClass("#icon");
  }
}

該組件的函數(shù)項(xiàng)根據(jù)輸入的圖標(biāo)類型創(chuàng)建圖標(biāo)組件并替換已有的 span 元素對(duì)象。注意,替換完后需要重新添加樣式。

子項(xiàng)的實(shí)現(xiàn)

按從內(nèi)到外的原則,接下來實(shí)現(xiàn)選項(xiàng)卡組件的子項(xiàng) TabItem。對(duì)于此組件,需要在組件的映射項(xiàng)中做一次異名的屬性映射,把 id 屬性值映射給內(nèi)部的圖標(biāo)組件的 icon 屬性。

TabItem: {
  css: "這里是樣式項(xiàng)部分,為便于組件整體展示,略去...",
  map: {"attrs": { icon: "id->icon" } },
  xml: `<a id="tabitem">
       <Icon id="icon"/>
       <span id="label">首頁(yè)</span>
     </a>`,
  fun: function (sys, items, opts) {
    sys.label.text(opts.label);
    function select() {
      sys.tabitem.addClass("#primary");
    }
    function unselect() {
      sys.tabitem.removeClass("#primary");
    }
    return { select: select, unselect: unselect };
  }
}

此組件提供了用于選項(xiàng)切換時(shí)選中與非選中狀態(tài)之間切換的接口。以供選項(xiàng)卡容器使用。

選項(xiàng)卡的實(shí)現(xiàn)

最后來看下選項(xiàng)卡組件 Tabbar 的實(shí)現(xiàn)。該組件偵聽了用戶觸擊選項(xiàng)卡時(shí)的事件,在偵聽器里主要做兩件事:一是維持選項(xiàng)卡狀態(tài)的切換;另一是派發(fā)一選項(xiàng)卡切換時(shí)的狀態(tài)改變事件。

Tabbar: {
  css: "這里是樣式項(xiàng)部分,為便于組件整體展示,略去...",
  xml: `<nav id="tabbar"/>`,
  fun: function (sys, items, opts) {
    var sel = this.first();
    this.on("touchend", "./*[@id]", function (e) {
      sel.value().unselect();
      (sel = this).value().select();
      this.trigger("switch", this.toString());
    });
    if (sel) sel.value().select();
  }
}

至此,一個(gè)選項(xiàng)卡組件算是完成了,下面來看下具體的一個(gè)應(yīng)用:

xmlplus("example", function (xp, $_, t) {
  $_().imports({
  Index: {
    xml: `<Footer id='footer'/>`,
    fun: function (sys, items, opts) {
      this.on("switch", (e, target) => console.log(target));
    }
  },
  Footer: {
    xml: `<Tabbar id="footer">
         <TabItem id="home" label="首頁(yè)"/>
         <TabItem id="setting" label="設(shè)置"/>
         <TabItem id="logs" label="日志"/>
         <TabItem id="about" label="關(guān)于"/>
       </Tabbar>`
  }
  });
});

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“xmlplus中如何實(shí)現(xiàn)選項(xiàng)卡組件”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

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

分享題目:xmlplus中如何實(shí)現(xiàn)選項(xiàng)卡組件-創(chuàng)新互聯(lián)
本文來源:http://muchs.cn/article10/dcpddo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、移動(dòng)網(wǎng)站建設(shè)網(wǎng)站導(dǎo)航、企業(yè)建站、動(dòng)態(tài)網(wǎng)站、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站