亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 16:40:35
字體:
來源:轉載
供稿:網友

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

選項卡組成

在具體實現之前,想像一下目標組件是如何使用的,對于設計會有莫大的幫助。通過觀察,可以將選項卡組件分為容器部分和子項部分,正如下面的 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>`  }  });});

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩欧美中文在线播放| 97国产精品免费视频| 日本精品久久久久影院| 欧美日韩成人黄色| 国产精品爽爽爽| 亚洲美女www午夜| 日韩av在线精品| 欧美性色19p| 久久久精品在线观看| 日韩中文字幕在线| 国产成人精品在线观看| 色先锋资源久久综合5566| 日韩欧美a级成人黄色| 久久久噜噜噜久久中文字免| 欧美尤物巨大精品爽| 性视频1819p久久| 国产欧美最新羞羞视频在线观看| 国产精品99免视看9| 欧美高清性猛交| 久久综合伊人77777| 97国产一区二区精品久久呦| 亚洲区免费影片| 亚洲精品美女久久| 欧美视频13p| 精品久久香蕉国产线看观看gif| 国产69精品久久久久久| 亚洲天堂视频在线观看| 91国产美女视频| 亚洲美女喷白浆| 亚洲一区亚洲二区亚洲三区| 亚洲女成人图区| 色婷婷av一区二区三区在线观看| 久久人91精品久久久久久不卡| 亚洲国产精品va在线| 欧美在线视频一二三| 亚洲a中文字幕| 国产伦精品免费视频| 亚洲精品99久久久久中文字幕| 国产精品成人观看视频国产奇米| 国产一区二区丝袜高跟鞋图片| 亚洲欧美自拍一区| 91大神福利视频在线| 亚洲 日韩 国产第一| 日韩av中文字幕在线免费观看| 永久555www成人免费| 欧美日韩福利视频| 精品一区二区三区四区在线| 91久久精品日日躁夜夜躁国产| 精品丝袜一区二区三区| 亚洲激情在线观看| 久久九九亚洲综合| 欧美大片在线看| 国产女精品视频网站免费| 亚洲国产精品yw在线观看| 欧美精品激情在线| 91日本在线视频| 欧美成人亚洲成人日韩成人| 992tv在线成人免费观看| 国产69精品久久久久99| 色一区av在线| 久久99视频精品| 亚洲一区二区三区在线免费观看| 一区二区福利视频| 在线观看欧美成人| 日韩国产精品一区| 亚洲欧美日韩另类| 国产精品无av码在线观看| 国产精品直播网红| 欧美最猛性xxxxx(亚洲精品)| 狠狠躁夜夜躁久久躁别揉| 亚洲老头同性xxxxx| 国产精品久久91| 成人免费视频xnxx.com| 欧美精品在线极品| 91久久国产婷婷一区二区| 97精品国产aⅴ7777| 欧美日韩国产一区二区| 精品亚洲va在线va天堂资源站| 日韩高清中文字幕| 精品中文字幕久久久久久| 亚洲第一国产精品| 国产精品草莓在线免费观看| 91成人在线播放| 日韩在线一区二区三区免费视频| 午夜精品在线观看| 国产999在线| 国产精品久久久久久久电影| 亚洲成人三级在线| 日韩国产精品视频| 国产欧美日韩精品在线观看| 亚洲精品欧美一区二区三区| 日韩电影中文 亚洲精品乱码| 日韩av在线免费| 久久精品视频播放| 播播国产欧美激情| 97在线免费观看| 亚洲精品www| 欧美激情视频在线免费观看 欧美视频免费一| 国产v综合v亚洲欧美久久| 久久91精品国产91久久跳| 国产亚洲精品久久| 久久久在线视频| 久久精品99无色码中文字幕| 日韩av网站电影| 日韩在线视频网| 亚洲欧美国产日韩中文字幕| 亚洲精品成人久久| 国产精品久久久久久久久久久久久久| 疯狂蹂躏欧美一区二区精品| 久久精品国产成人精品| 久久久久中文字幕2018| 国产69精品久久久久99| 中文字幕久久亚洲| 91精品久久久久久久久中文字幕| 影音先锋欧美精品| 国产盗摄xxxx视频xxx69| 国产精品嫩草影院一区二区| 91性高湖久久久久久久久_久久99| 国产精品自拍偷拍视频| 91在线免费观看网站| 亚洲精品资源美女情侣酒店| 夜夜嗨av一区二区三区免费区| 97视频在线观看亚洲| 国产精品wwww| 欧美日韩一二三四五区| 日韩免费视频在线观看| 全球成人中文在线| 国产午夜一区二区| 黄色一区二区三区| 国产精品99久久99久久久二8| 日韩少妇与小伙激情| 91美女片黄在线观看游戏| 亚洲国产成人精品久久| 久久99久久亚洲国产| 91网站免费观看| 中文字幕亚洲综合久久| 成人h视频在线| 国产91色在线|| 日韩精品在线免费观看| 亚洲v日韩v综合v精品v| 91免费看片网站| 成人黄色免费片| 综合国产在线视频| 亚洲已满18点击进入在线看片| 日韩中文字幕亚洲| 国产精品高潮在线| 色偷偷亚洲男人天堂| 久久久国产影院| 精品电影在线观看| 中文字幕成人在线| 中文字幕日韩av电影| 日韩欧美在线免费观看| 国产成人精品电影久久久| 色综合男人天堂| 亚洲欧美成人精品| 亚洲男人天天操| 久久99精品国产99久久6尤物| 国产日韩精品视频| 91九色精品视频| 国产精品视频不卡| 日本伊人精品一区二区三区介绍| 57pao成人永久免费视频| 亚洲欧洲在线免费| 91国产在线精品|