摘要:設置為,相對于高度為的來說就是。再看這一堆使用最關鍵的一點就是計算和的值。可以看到回調里可以拿到,也就是對象的實例,當?shù)扔诖頋L到了底部,所以這里加上代表快要滾動底部已經看到了加載更多。開始任何意見和建議歡迎,團隊會第一時間反饋。
原文鏈接:https://github.com/AlloyTeam/AlloyTouch/wiki/kandian
先驗貨訪問DEMO你也可以點擊這里
源代碼可以點擊這里
如你體驗所見,流程的滾動的同時還能支持頭部的動畫?不斷地加載新數(shù)據(jù)還能做到流暢的滑動!怎么做得的?使用AlloyTouch CSS 0.2.0及以上版本便可!
頭部動畫 加載更多 實現(xiàn)代碼var infoList = document.getElementById("infoList"), mockHTML = infoList.innerHTML, scroller = document.getElementById("scroller"), header = document.getElementById("header"), userLogo = document.getElementById("user-logo-wrapper"), loading = false, alloyTouch = null; Transform(scroller, true); Transform(header); header.originY = -70; header.translateY = -70; Transform(userLogo); alloyTouch = new AlloyTouch({ touch: "#wrapper", vertical: true, target: scroller, property: "translateY", maxSpeed: 2, outFactor: 0.1, min: 160 * -20 + window.innerHeight - 202 - 50, max: 0, lockDirection: false, touchStart: function () { reastMin(); }, lockDirection: false, change: function (v) { if (v <= this.min + 5 && !loading) { loading = true; loadMore(); } if (v < 0) { if (v < -140) v = -140; var scaleY = (240 + v) / 240; header.scaleY = scaleY; userLogo.scaleX = userLogo.scaleY = scaleY; userLogo.translateY = v / 1.7; } else { var scaleY = 1 + v / 240; header.scaleY = scaleY; userLogo.scaleX = userLogo.scaleY = scaleY; userLogo.translateY = v / 1.7; } } }) function loadMore() { setTimeout(function () { infoList.innerHTML += mockHTML; loading = false; reastMin(); }, 500) } function reastMin() { alloyTouch.min = -1 * parseInt(getComputedStyle(scroller).height) + window.innerHeight - 202; } document.addEventListener("touchmove", function (evt) { evt.preventDefault(); }, false);
就這么多代碼。當然你要引用一個transformjs和alloy_touch.css.js。先看這一堆:
Transform(scroller, true); Transform(header); header.originY = -70; header.translateY = -70; Transform(userLogo);
Transform(xxx)是什么意思?
賦予xxx transformation能力
第一個scroller加上true代表關閉透視投影,為什么要關閉透視投影?
因為scroller里面是有文本,防止文本在IOS中模糊的情況。
header是頂部的那個藍色的區(qū)域。為什么要設置originY和translateY?為什么要設置為-70?
因為header的高度為140px,用戶向上滾動的過程中,需要對其進行scaleY變換。通常我們的做法是設置CSS3 transform-origin為 center top。而使用transformjs之后,可以拋棄transform-origin,使用originY或者originX屬性便可。originY 設置為 -70,相對于高度為140的header來說就是center top。
再看這一堆:
alloyTouch = new AlloyTouch({ touch: "#wrapper", vertical: true, target: scroller, property: "translateY", maxSpeed: 2, outFactor: 0.1, lockDirection: false, min: 160 * -20 + window.innerHeight - 202 - 50, max: 0, touchStart: function () { resetMin(); }, lockDirection: false, ... ... ... }) ... ... function resetMin() { alloyTouch.min = -1 * parseInt(getComputedStyle(scroller).height) + window.innerHeight - 202; }
使用AlloyTouch最關鍵的一點就是計算min和max的值。min和max決定了可以滾到哪里,到了哪里會進行回彈等等。這里max是0毫無疑問。
但是min那一堆加減乘除是什么東西?
這里首次加載是20行數(shù)據(jù),每一行高度大概160,主意是大概, window.innerHeight是視窗的高度,202px是滾動的容器的padding top的值,50px是用來留給顯示加載更多的...
如上圖所示,主要是需要求???的高度。
那么怎么解決大概160*20的問題?
touchStart的時候reastMin。resetMin會去通過getComputedStyle計算整個scroller的高度。
maxSpeed是干什么用的?
用來限制滾動的最大速度,個人感覺調整到2挺舒適,這個可以根據(jù)場景和被運動的屬性靈活配置。
outFactor是干什么用的?
用來設置超出min或者max進行拖拽的運動比例系數(shù),系數(shù)越小,超出min和max越難拖動,也就是受到的阻力越大。
lockDirection是干什么用的?
lockDirection默認值是true。代表用戶起手時候是橫向的,而你監(jiān)聽的是豎直方向的touch,這樣的話是不會觸發(fā)運動。只有起手和監(jiān)聽對應上才會有觸摸運動。這里把lockDirection設置成false就沒有這個限制,不管用戶起手的direction,都會有觸摸運動。
再看AlloyTouch注入的change事件!頭部動效核心的一個配置函數(shù):
change: function (v) { if (v <= this.min + 5 && !loading) { loading = true; loadMore(); } if (v < 0) { if (v < -140) v = -140; var scaleY = (240 + v) / 240; header.scaleY = scaleY; userLogo.scaleX = userLogo.scaleY = scaleY; userLogo.translateY = v / 1.7; } else { var scaleY = 1 + v / 240; header.scaleY = scaleY; userLogo.scaleX = userLogo.scaleY = scaleY; userLogo.translateY = v / 1.7; } }
v代表當前被運動對象的被運動屬性的當前的值,根據(jù)這個v去做一些效果和加載更多。
什么時候加載更多?
當滾動你能看到加載更多的時候去加載更多
什么時候能看到加載更多?
v <= this.min + 5。 可以看到change回調里可以拿到this,也就是AlloyTouch對象的實例,當v等于this.min代表滾到了底部,所以這里加上5代表快要滾動底部已經看到了加載更多。就去執(zhí)行l(wèi)oadMore函數(shù)。
loading是干什么用的?
防止重復loadMore用得,因為change執(zhí)行得很頻繁,所以這里會通過loading的狀態(tài)去鎖上。
下面一堆設置scaleX、scaleY、translateY以及一堆數(shù)字是怎么來的?
慢慢調試得出的最佳效果~~反正就是根據(jù)v的數(shù)值映射到 header和用戶頭像的transform屬性上,這里就不一一講了。
再看loadMore:
function loadMore() { setTimeout(function () { infoList.innerHTML += mockHTML; loading = false; reastMin(); }, 500) }
這里使用了一段假的HTML去模擬AJAX異步請求以及數(shù)據(jù)轉HTML的過程,整個耗時500ms,500ms后會去:
插入HTML
重置loading狀態(tài)
重置AlloyTouch的min
最后:
document.addEventListener("touchmove", function (evt) { evt.preventDefault(); }, false);
阻止掉整個document的默認事件,不會把整個頁面拖下來,在手Q里的話,你就看不到網址和X5內核提供技術支持了。
開始AlloyTouchGithub:https://github.com/AlloyTeam/AlloyTouch
任何意見和建議歡迎new issue,AlloyTouch團隊會第一時間反饋。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/86686.html
摘要:你應該知道的種設計模式前端掘金每位開發(fā)者都努力寫出可維護的易讀的可復用的代碼。繼承關系本前端書籍整理,高清前端掘金發(fā)現(xiàn)了一個下載前端書籍的地方,分享給大家。 你應該知道的 4 種 JavaScript 設計模式 - 前端 - 掘金每位開發(fā)者都努力寫出可維護的、易讀的、可復用的代碼。隨著應用變得越來越大,代碼的結構也越來越重要。設計模式驗證了解決這個挑戰(zhàn)的重點——在特定環(huán)境中,對同類事物...
摘要:但是在某些場景下,還是需要擁有自身的下拉刷新的能力。比如需要統(tǒng)一和安卓的體驗需要自定義下拉刷新動畫需要已內的背景或者其他元素有聯(lián)動交互反饋而拖動整個的下拉刷新無法滿足這些場景。很明顯非常擅長處理下拉刷新的需求。 原文地址:https://github.com/AlloyTeam/AlloyTouch/wiki/Pull-to-refresh 效果展示 showImg(https://s...
原文鏈接:https://github.com/AlloyTeam/AlloyTouch/wiki/AlloyTouch-FullPage-Plugin 先驗貨 showImg(https://segmentfault.com/img/remote/1460000007885626?w=280&h=280); 插件代碼可以在這里找到。 注意,雖然是掃碼體驗,但是AlloyTouch.FullPag...
閱讀 1053·2021-11-15 18:11
閱讀 3172·2021-09-22 15:33
閱讀 3469·2021-09-01 11:42
閱讀 2663·2021-08-24 10:03
閱讀 3629·2021-07-29 13:50
閱讀 2931·2019-08-30 14:08
閱讀 1281·2019-08-28 17:56
閱讀 2266·2019-08-26 13:57