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

首頁 > 編程 > JavaScript > 正文

xmlplus組件設計系列之下拉刷新(PullRefresh)(6)

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

“下拉刷新”由著名設計師 Loren Brichter 設計,并應用于 Twitter 第三方應用 Tweetie 中。2010年4月,Twitter 收購 Tweetie 開發商 Atebits 后,該專利歸 Twitter 所有。這一章我們就來看看如何實現一個簡單的下拉刷新組件。

目標組件分析

和前面在設計組件時的做法一樣,我們先想想看最終的成品組件是如何使用的,這需要點想像力。下拉刷新組件看成一個容器組件是合理的,用戶可以對容器的內容進行下拉操作。如果用戶完成了完整的下拉觸發操作,該組件應該會有下拉完成的事件反饋,假定這個事件名為 ready。根據以上的分析,我們很有可能得到下面的一個該組件的應用示例。

Example1: { xml: `<PullRefresh id='example'>    <h1>Twitter</h1>    <h2>Loren Brichter</h2>   </PullRefresh>`, fun: function (sys, items, opts) {  sys.example.on("ready", () => console.log("ready")); }}

示例中的使用方式是非常簡潔的,但我們還漏了一點。如果你用過一些新聞客戶端,在某些情況下,此客戶端會自動觸發下拉刷新操作。比如,剛進入客戶端頁面或者由于軟件推送機制產生的被動列表更新,這都將導致客戶端下拉刷新操作的觸發。所以如上的 PullRefresh 組件還應該提供一個觸發自動刷新的操作接口。好了,下面是加入下拉刷新接口的應用示例。

Example2: { xml: `<PullRefresh id='example'>    <h1>Twitter</h1>    <h2>Loren Brichter</h2>    <button id='refresh'>click</button>   </PullRefresh>`, fun: function (sys, items, opts) {  sys.example.on("ready", () => console.log("ready"));  sys.refresh.on("click", items.example.refresh); }}

基本框架

現在讓我們把目光轉移到下拉刷新組件的內部,看看該如何去實現。觀察文章開始部分的大圖,很自然地我們可以將整個組件劃分為三個子組件,如下面的 XML 文檔所示。

<div id="refresh"> <Status id="status"/> <div id="content"></div></div>

外圍 div 元素包含兩個子組件:其中一個是狀態指示條,用于顯示“下拉刷新”、“松開刷新”、“加載中...”以及“刷新成功”四個狀態提示,這里暫時使用未定義的 Status 組件替代;另一個 div 元素用于容納下拉刷新組件的包含內容。到現在,大概可以想得出該組件的工作邏輯了,于是我們可以給出下面的一個基本的組件框架。

PullRefresh: { css: "#refresh { position: relative; height: 100%;...}", xml: `<div id="refresh">   <Status id="status"/>   <div id="content"/>   </div>`, map: { appendTo: "content" }, fun: function (sys, items, opts) {  sys.content.on("touchstart", e => {   // 偵聽 touchmove 和 touchend事件  });  function touchmove(e) {   // 1 處理狀態條與內容內面跟隨觸點移動   // 2 根據觸點移動的距離顯示相當的狀態條內容  }  function touchend(e) {   // 1 移除 touchmove 和 touchend 事件   // 2 根據觸點移動的距離決定返回原始狀態或者進入刷新狀態并派發事件  } }}

狀態條的實現

如前面提到的,狀態條組件包含四個狀態提示,并且每一時刻僅顯示一個狀態。對于狀態的切換,這里會先用到我們下一章將講到的路由組件 ViewStack,這里僅需要了解如何使用即可。組件 ViewStack 對外只顯示子級的一個子組件,同時偵聽一個 switch 事件,該事件的派發者攜帶了一個切換到的目標對象的名稱,也就是 ID。該組件根據這個 ID 來切換到目標視圖。下面是狀態條組件的完整實現。

Status: { css: "#statusbar { height: 2.5em; line-height: 2.5em; text-align: center; }", xml: <ViewStack id="statusbar">   <span id="pull">下拉刷新</span>   <span id="ready">松開刷新</span>   <span id="loading">加載中...</span>   <span id="success">刷新成功</span>   </ViewStack>, fun: function (sys, items, opts) {  var stat = "pull";  function getValue() {   return stat;  }  function setValue(value) {   sys.statusbar.trigger("switch", stat = value);  }  return Object.defineProperty({}, "value", { get: getValue, set: setValue }); }}

該組件提供一個 value 接口用戶設置與獲取組件的顯示狀態。父級組件可根據不同的時機調用該接口。

最終實現

有了上面的儲備,讓我們來填充完下拉刷新組件的細節。下拉刷新過程中會涉及到動畫,對于動畫目前一般有兩種選擇,可以使用 JQuery 動畫函數,也可以是 css3,這需要看各人喜好了。這里我們選擇使用 css3 來實現。為清晰起見,下面的實現僅給出函數部分,其余部分同上。

PullRefresh: { fun: function (sys, items, opts) {  var startY, height = sys.status.height();  sys.content.on("stouchstart", e => {   if (items.status.value == "pull") {    startY = e.y;    sys.content.on("touchmove", touchmove).on("touchend", touchend);    sys.content.css("transition", "").prev().css("transition", "");   }  });  function touchmove(e) {   var offset = e.y - startY;   if ( offset > 0 ) {    sys.content.css("top", offset + "px");     sys.status.css("top", (offset - height) + "px");    items.status(offset > height ? "ready" : "pull");   }  }  function touchend (e) {   var offset = e.y - startY;   sys.content.off("touchmove").off("touchend");   sys.content.css("transition", "all 0.3s ease-in 0s").prev().css("transition", "all 0.3s ease-in 0s");   if ( offset < height ) {    sys.content.css("top", "0").prev().css("top", -height + "px");   } else {    items.status.value = "release";    sys.refresh.once("complete", complete);    sys.content.css("top", height + "px").prev().css("top", "0").trigger("ready");   }  }  function complete() {   items.status.value = "message";   setTimeout(() => {    sys.content.css("top", "0").prev().css("top", -height + "px");    sys.content.once("webkitTransitionEnd", e => items.status.value = "pull");   }, 300);  } }}

對于稍微有點復雜的組件,需要注意組件的組織歸類,盡量把具有相近功能的組件放在一起。為了便于敘述,上述所列出的組件示意總把它們視作是同一目錄,這一點讀者應該能看出來。

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线观看网址综合| 一区二区三区国产视频| 亚洲丁香婷深爱综合| 亚洲欧美日本伦理| 久久成人精品视频| 欧美激情视频一区| 91视频国产精品| 国产区亚洲区欧美区| 久久大大胆人体| 欧美亚洲视频一区二区| 国产成人一区二区三区| 亚洲二区中文字幕| 欧美视频二区36p| 亚洲高清福利视频| 欧美激情女人20p| 91高潮在线观看| 成人福利网站在线观看11| 尤物99国产成人精品视频| 欧美性20hd另类| 欧美精品福利视频| 欧美电影在线观看完整版| 亚洲欧美一区二区激情| 久久久影视精品| 亚洲午夜未删减在线观看| 俺去啦;欧美日韩| 久久久在线观看| 日韩综合中文字幕| 欧美xxxx18性欧美| 热久久免费视频精品| 欧美精品福利在线| 91精品国产免费久久久久久| 日韩高清电影好看的电视剧电影| 国产亚洲福利一区| 日韩av电影在线免费播放| 色妞色视频一区二区三区四区| 九九综合九九综合| 成人中心免费视频| 日韩欧美在线视频观看| 国产欧美一区二区三区久久人妖| 精品一区二区三区电影| 91精品在线观| 亚洲国产精品999| 日本高清视频精品| 欧美日韩一区二区三区在线免费观看| 2019日本中文字幕| 高清一区二区三区四区五区| 亚洲人成电影在线播放| 国产va免费精品高清在线观看| 国产精品福利小视频| 欧美一级大片在线免费观看| 色七七影院综合| 色先锋资源久久综合5566| 欧美日韩国产一区二区| 国产精品视频资源| 综合av色偷偷网| 国产精品老女人视频| 国产欧美日韩免费看aⅴ视频| 精品视频在线播放| 欧美日韩国产精品| 美女撒尿一区二区三区| 国产91热爆ts人妖在线| 亚洲欧洲日本专区| 韩国三级电影久久久久久| 亚洲人成电影网站| 中文字幕日韩精品在线观看| 成人国产精品色哟哟| 久久久久久国产精品三级玉女聊斋| 欧洲永久精品大片ww免费漫画| 欧美日韩中国免费专区在线看| 欧美极品少妇xxxxⅹ免费视频| 欧美成人午夜激情视频| 国外成人免费在线播放| 日韩国产激情在线| 亚洲va欧美va国产综合剧情| 国产激情视频一区| 欧美亚州一区二区三区| 久久艳片www.17c.com| 91沈先生作品| 日韩中文视频免费在线观看| 91在线观看免费观看| 综合久久五月天| 日本一区二区三区四区视频| 久久久国产影院| 亚洲第一网中文字幕| 亚洲欧洲xxxx| 日韩视频―中文字幕| 亚洲欧洲高清在线| 国产亚洲精品美女久久久久| 国产精品久久久久久久美男| 日韩高清免费在线| 日本亚洲精品在线观看| 日韩69视频在线观看| 久久久久久久国产精品视频| 美日韩精品免费观看视频| 亚洲区在线播放| 国产一区二区三区在线看| 57pao精品| 欧美电影免费看| 欧美日韩国产综合视频在线观看中文| 91日本在线视频| 国产精品一区二区av影院萌芽| 亚洲国产高清福利视频| 亚洲女人天堂色在线7777| 欧美日韩裸体免费视频| 欧美精品性视频| 日韩成人在线网站| 亚洲欧美激情四射在线日| 久久黄色av网站| 久久99热精品这里久久精品| 久久精品视频免费播放| 国产欧美日韩视频| 色999日韩欧美国产| 欧美成年人视频| 欧美高清理论片| 国产精品v日韩精品| 亚洲男人天堂2019| 九九热精品在线| 在线一区二区日韩| 国产日韩视频在线观看| 日本久久久久久久久| 亚洲国产精品久久久久久| 九九久久久久99精品| 国产精品久久久av久久久| 亚洲女同精品视频| 欧美福利在线观看| 国产精品视频一| 欧美成aaa人片免费看| 中文字幕国产精品| 亚洲国产小视频在线观看| 中日韩午夜理伦电影免费| 欧美性受xxxx黑人猛交| 精品久久久香蕉免费精品视频| 九九九久久久久久| 亚洲精品欧美一区二区三区| 国产成人精品一区二区三区| 日韩精品在线视频| 97视频免费观看| 亚洲欧美国产一区二区三区| 亚洲第一级黄色片| 国产成人精品999| 国产综合香蕉五月婷在线| 亚洲成人网av| 成人性生交大片免费看视频直播| 最新69国产成人精品视频免费| 欧美高跟鞋交xxxxhd| 91午夜在线播放| 91中文字幕一区| 精品久久久久久久久久久久| 久久精品国产成人| 欧美激情xxxx| 亚洲精品自拍偷拍| 亚洲人成网7777777国产| 欧美自拍视频在线| 亚洲自拍欧美色图| 亚洲美女av网站| 国产精品久久久久久五月尺| 亚洲xxxx妇黄裸体| 国产精品久久一区主播| 亚洲第一视频网站| 国产成人综合精品| 欧美精品久久久久a| 日本aⅴ大伊香蕉精品视频| 精品在线观看国产| 欧美一区二区三区艳史|