欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

xmlplus組件設(shè)計系列之選項卡(Tabbar)(5)

 更新時間:2017年05月03日 09:28:17   作者:qudou  
xmlplus 是一個JavaScript框架,用于快速開發(fā)前后端項目。這篇文章主要介紹了xmlplus組件設(shè)計系列之選項卡,具有一定的參考價值,感興趣的小伙伴們可以參考一下

這一章將設(shè)計一個選項卡組件,選項卡組件在手持設(shè)備上用的比較多,下面是一個示意圖:

選項卡組成

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

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


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

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

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

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

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

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

圖標的實現(xiàn)

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

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 之下,也就是你要像下面這樣導(dǎo)入:

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

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

下面來實現(xiàn)圖標組件 Icon,這里的圖標組件與上面是不同的,它會根據(jù)輸入的圖標類型實例化不同的圖標。這樣設(shè)計可以復(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ù)項根據(jù)輸入的圖標類型創(chuàng)建圖標組件并替換已有的 span 元素對象。注意,替換完后需要重新添加樣式。

子項的實現(xiàn)

按從內(nèi)到外的原則,接下來實現(xiàn)選項卡組件的子項 TabItem。對于此組件,需要在組件的映射項中做一次異名的屬性映射,把 id 屬性值映射給內(nèi)部的圖標組件的 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 };
  }
}

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

選項卡的實現(xiàn)

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

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

至此,一個選項卡組件算是完成了,下面來看下具體的一個應(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="首頁"/>
         <TabItem id="setting" label="設(shè)置"/>
         <TabItem id="logs" label="日志"/>
         <TabItem id="about" label="關(guān)于"/>
       </Tabbar>`
  }
  });
});


在組件 Index 中,你可以偵聽來自選項卡的切換事件來做相應(yīng)的操作。比如結(jié)合后續(xù)我們介紹的視圖棧組件做頁面之間的切換操作。

本系列文章基于 xmlplus 框架。如果你對 xmlplus 沒有多少了解,可以訪問 www.xmlplus.cn。這里有詳盡的入門文檔可供參考。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js代碼實現(xiàn)多人聊天室

    js代碼實現(xiàn)多人聊天室

    這篇文章主要為大家詳細介紹了js代碼實現(xiàn)多人聊天室,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Bootstrap Table 搜索框和查詢功能

    Bootstrap Table 搜索框和查詢功能

    這篇文章主要介紹了Bootstrap Table 搜索框和查詢功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-11-11
  • js中for-in和for-of的區(qū)別詳解

    js中for-in和for-of的區(qū)別詳解

    在JavaScript中,for-in和for-of是兩種不同的循環(huán)結(jié)構(gòu),本文主要介紹了js中for-in和for-of的區(qū)別,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 使用JS代碼實現(xiàn)頁面添加水印的方法詳解

    使用JS代碼實現(xiàn)頁面添加水印的方法詳解

    這篇文章主要介紹了使用80 行 JS 代碼實現(xiàn)頁面添加水?。何淖炙?、多行文字水印、圖片水印、文字&圖片水印,文中通過代碼示例給大家介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下
    2024-05-05
  • use jscript with List Proxy Server Information

    use jscript with List Proxy Server Information

    use jscript with List Proxy Server Information...
    2007-06-06
  • Webpack 4如何動態(tài)切割JS注入文件名詳解

    Webpack 4如何動態(tài)切割JS注入文件名詳解

    這篇文章主要給大家介紹了關(guān)于Webpack 4如何動態(tài)切割JS注入文件名的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Webpack4具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • js制作可以延時消失的菜單

    js制作可以延時消失的菜單

    這篇文章主要為大家詳細介紹了基于JavaScript制作可以延時消失的菜單,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • JavaScript中cookie工具函數(shù)封裝的示例代碼

    JavaScript中cookie工具函數(shù)封裝的示例代碼

    這篇文章給大家主要介紹了JavaScript中cookie工具函數(shù)的封裝,文中給出了詳細的實現(xiàn)步驟和示例代碼,相信會對大家的理解很有幫助,有需要的朋友們下面來一起看看吧。
    2016-10-10
  • 基于Cesium實現(xiàn)加載顯示熱力圖

    基于Cesium實現(xiàn)加載顯示熱力圖

    這篇文章主要介紹了如何利用Cesium實現(xiàn)加載顯示熱力圖,文中的示例代碼講解詳細,對我們學習或工作有一定的幫助,需要的可以參考一下
    2022-06-06
  • 詳談javascript中的cookie

    詳談javascript中的cookie

    cookie其實就是網(wǎng)站放在用戶機器上的一小塊信息,cookie對于用戶來說是唯一的,網(wǎng)站可判斷用戶上次訪問網(wǎng)站的時間,以及他訪問了哪些頁面,可用于在某個網(wǎng)站跟蹤你訪問的頁面,但無法用它來獲取個人信息。
    2015-06-06

最新評論