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

溫馨提示×

溫馨提示×

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

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

xmlplus中如何實現選項卡組件

發布時間:2021-08-13 13:34:53 來源:億速云 閱讀:110 作者:小新 欄目:web開發

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

示意圖:

xmlplus中如何實現選項卡組件

選項卡組成

在具體實現之前,想像一下目標組件是如何使用的,對于設計會有莫大的幫助。通過觀察,可以將選項卡組件分為容器部分和子項部分,正如下面的 XML 結構所展示的。

<Tabbar id="tabbar">
  <TabItem id="home" label="首頁"/>
  <TabItem id="setting" label="設置"/>
  <TabItem id="logs" label="日志"/>
  <TabItem id="about" label="關于"/>
</Tabbar>

現在我們把目光切換到選項卡組件的子項部分,來看看子項部分是如何分解的。通過示意圖,你可以發現子項部分可以分解為子項容器以及包含一個圖標和一個文本的子級部分。

<a id="tabitem">
  <Icon id="icon"/>
  <span id="label">首頁</span>
</a>

所以,現在我們的目標已經很明確了,主要設計三個組件:圖標組件 Icon、選項卡組件的子項 TabItem 以及選項卡組件的容器 Tabbar。

結構圖

由于該組件比較簡單,所以可以將三種子組件放置在同一層級。但請注意,我們還有四個圖標組件,可以創建一個子級用于容納它們。下面給出我們的組件結構圖:

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

圖標的實現

我們從最簡單的開始,先看四個圖標組件,圖標組件主要通過封裝 SVG 文本來實現,由于圖標文本較長,所以這里僅截取每個圖標文本的一段。

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>`
}

請注意,這些圖標位于虛擬目錄 /icon 之下,也就是你要像下面這樣導入:

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

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

下面來實現圖標組件 Icon,這里的圖標組件與上面是不同的,它會根據輸入的圖標類型實例化不同的圖標。這樣設計可以復用部分相同的代碼,避免冗余。

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");
  }
}

該組件的函數項根據輸入的圖標類型創建圖標組件并替換已有的 span 元素對象。注意,替換完后需要重新添加樣式。

子項的實現

按從內到外的原則,接下來實現選項卡組件的子項 TabItem。對于此組件,需要在組件的映射項中做一次異名的屬性映射,把 id 屬性值映射給內部的圖標組件的 icon 屬性。

TabItem: {
  css: "這里是樣式項部分,為便于組件整體展示,略去...",
  map: {"attrs": { icon: "id->icon" } },
  xml: `<a id="tabitem">
       <Icon id="icon"/>
       <span id="label">首頁</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 };
  }
}

此組件提供了用于選項切換時選中與非選中狀態之間切換的接口。以供選項卡容器使用。

選項卡的實現

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

Tabbar: {
  css: "這里是樣式項部分,為便于組件整體展示,略去...",
  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();
  }
}

至此,一個選項卡組件算是完成了,下面來看下具體的一個應用:

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="首頁"/>
         <TabItem id="setting" label="設置"/>
         <TabItem id="logs" label="日志"/>
         <TabItem id="about" label="關于"/>
       </Tabbar>`
  }
  });
});

感謝你能夠認真閱讀完這篇文章,希望小編分享的“xmlplus中如何實現選項卡組件”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

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

AI

赤壁市| 卫辉市| 英德市| 青冈县| 罗定市| 揭西县| 东光县| 呈贡县| 达拉特旗| 巴青县| 大悟县| 金门县| 罗甸县| 海晏县| 北宁市| 郎溪县| 明溪县| 江永县| 巧家县| 顺义区| 固阳县| 沧州市| 高阳县| 唐海县| 合水县| 庆阳市| 始兴县| 宿迁市| 河津市| 平凉市| 章丘市| 萨嘎县| 凤阳县| 宝鸡市| 建昌县| 长泰县| 年辖:市辖区| 柞水县| 崇阳县| 万宁市| 永善县|