基于iSroll 5.0實現的上拉加載和下拉刷新插件

Updownload.js

基于iSroll 5.0實現的上拉加載和下拉刷新插件

移動端效果比較好,開發者工具打開后,需要刷新下頁面。

[演示地址:] https://chenyk2016.github.io/upDownLoad/demo.html
[github地址:] https://github.com/chenyk2016/upDownLoad/

效果圖

1150849-20171029150936148-1897024875.gif

1.建立html

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /><title>下拉刷新,上拉加載</title>
</head>
<body>
<h2>IScroll上拉加載下拉刷新</h2>
<div class="iscroll_wrap" id="iscroll_wrap"><div class="iscroll"><!-- 方案列表 --><div class="task_wrap" ><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P></div></div>
</div>
</body>
</html>

兩個容器iscroll_wrap和iscroll;
iscroll為滾動元素,iscroll_wrap為固定大小的容器。
可以在iscroll里新建列表等

2.樣式和圖片

<style type="text/css">*{ padding: 0;margin: 0; }h2{ text-align: center; border-bottom: 1px solid #ccc; height: 40px; background-color: #eee; }.iscroll_wrap { position: absolute; top: 40px; bottom: 0; width: 100%; background-color: #ccc; overflow: hidden; }/* min-height: 101%; 是避免內容高度小于.iscroll_wrap 的高度時,無法使用iScroll*/.iscroll { position: absolute; top: 0; left: 0; width: 100%; min-height: 101%; background-color: #fff; }.iscroll .loading { background: url(./img/loading.gif) no-repeat left center; padding-left: 30px; }
</style>

注:
iscroll的min-height: 101%; 是避免內容高度小于.iscroll_wrap的高度時,無法使用iScroll

3.引入js文件

<script src="iscroll-probe.js"></script>  // 引入iScroll插件
<script src="./js/updownload.js"></script>  // 擴展的源碼
<script type="text/javascript">// 1.創建實例var myRefresh = new UpDownLoad( "#iscroll_wrap" );// 2.綁定事件 myRefresh.on("pullDown", function (d) {// 下拉事件觸發行為myRefresh.success(function (d) {// 刷新成功后執行});myRefresh.error(function (d) {// 刷新失敗后執行});}).on("pullUp",function (d) {// 上拉事件觸發行為myRefresh.success(function (d) {// 上拉成功后執行  });myRefresh.error(function (d) {// 上拉失敗后執行});});</script>

注意:
上拉和下拉都有兩個狀態。為了顯示成功狀態之前執行刷新DOM,需要將操作DOM的行為放在回調里執行。
myRefresh.success(fn);
myRefresh.error(fn);
如果想看具體實現,可以查看代碼源文件updownload.js

完整演示

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /><title>下拉刷新,上拉加載</title><style type="text/css">
*{ padding: 0;margin: 0; }
h2{ text-align: center; border-bottom: 1px solid #ccc; height: 40px; background-color: #eee; }
.iscroll_wrap { position: absolute; top: 40px; bottom: 0; width: 100%; background-color: #ccc; overflow: hidden; }
/* min-height: 101%; 是避免內容高度小于.iscroll_wrap 的高度時,無法使用iScroll*/
.iscroll { position: absolute; top: 0; left: 0; width: 100%; min-height: 101%; background-color: #fff; }
.iscroll .loading { background: url(./img/loading.gif) no-repeat left center; padding-left: 30px; }</style>
</head>
<body>
<h2>IScroll上拉加載下拉刷新</h2>
<div class="iscroll_wrap" id="iscroll_wrap"><div class="iscroll"><!-- 方案列表 --><div class="task_wrap" ><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P><P>das</P></div></div>
</div></body>
<script src="iscroll-probe.js"></script>
<script src="./js/updownload.js"></script>
<script type="text/javascript">// 使用window.onload = function () {var myRefresh = new UpDownLoad( "#iscroll_wrap" );myRefresh.on("pullDown", function (d) {console.log('pullDown');// 延時器模擬正在加載效果var taskWrap = document.querySelector(".task_wrap");taskWrap.innerHTML = "";setTimeout(function (res) {// 刷新成功后執行myRefresh.success(function (d) {var taskWrap = document.querySelector(".task_wrap");taskWrap.innerHTML = "<p>刷新as</p><p>a刷新s</p><p>刷新as</p><p>as</p><p>as</p><p>as</p><p>as</p><p>as</p><p>as</p><p>as</p>";});// 刷新失敗后執行// myRefresh.error();}, 1000);} ).on("pullUp", function (d) {console.log('pullUp');setTimeout(function (res) {// 加載成功后執行myRefresh.success(function () {var taskWrap = document.querySelector(".task_wrap");var dom = document.createElement("div");dom.innerHTML = "<p>加載</p><p>加載</p><p>加載</p><p>加載</p><p>加載</p><p>加載</p><p>as</p><p>as</p><p>as</p><p>as</p><p>as</p><p>as</p>";taskWrap.appendChild(dom);});// 加載失敗后執行// myRefresh.error();}, 1000);});};
</script>
</html>

關注我

github [https://github.com/chenyk2016]
博客園 [https://home.cnblogs.com/u/chenykblog/]

轉載于:https://www.cnblogs.com/chenykblog/p/7750067.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/287336.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/287336.shtml
英文地址,請注明出處:http://en.pswp.cn/news/287336.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[小白進] 大佬們學習為什么簡單?小白該如何學習?學歷不高如何找工作?副業很好賺?了解后少走彎路

一、前言 對于新手來說&#xff0c;最開始學習編程的難度不亞于學天書&#xff0c;那為什么有經驗的程序員在接觸一門新技術時能夠快速的上手并且完成一些需求的開發呢&#xff1f; 有些人可能看了這個問題覺得我在說廢話&#xff0c;“有經驗那不快那怎么才快&#xff1f;”…

Chrome如何離線安裝crx文件

2019獨角獸企業重金招聘Python工程師標準>>> 在Chrome瀏覽器的谷歌網上應用商店Chrome Web Store上點擊應用安裝按鈕「添加至Chrome」&#xff0c;變成下載文件。把下載文件一拖進瀏覽器也不能安裝。下面是如何離線安裝crx文件的方法&#xff1a; ①點擊Google Chr…

新坑

最近準備多看一些論文辣&#xff0c;先大體整理一下要看的東西淺談啟發式思想在信息學競賽中的應用后綴自動機及其應用淺談分塊在一類在線問題中的應用淺談圖的匹配算法及其應用Dp的一些優化技巧對置換群有關算法的初步研究線段樹在一類分治問題上的應用慢慢填吧轉載于:https:/…

【Envi風暴】Envi 5.1平臺下植被覆蓋度(VFC)的遙感估算

【導讀】植被覆蓋度是指植被(包括葉、莖、枝)在地面的垂直投影面積占統計區面積的百分比。常用的計算方法有:經驗模型法、植被指數法、像元分解模型法、FCK模型法、決策樹分類法和神經網絡法。本文利用像元二分模型計算植被覆蓋度(VFC)。 一、數據 張掖市Landsat TM影像(…

基于.NetCore開發博客項目 StarBlog - (6) 頁面開發之博客文章列表

系列文章基于.NetCore開發博客項目 StarBlog - (1) 為什么需要自己寫一個博客&#xff1f;基于.NetCore開發博客項目 StarBlog - (2) 環境準備和創建項目基于.NetCore開發博客項目 StarBlog - (3) 模型設計基于.NetCore開發博客項目 StarBlog - (4) markdown博客批量導入基于.N…

時間序列matlab代碼,MATLAB在時間序列建模預測及程序代碼.pdf

第二十四章 時間序列模型時間序列是按時間順序排列的、隨時間變化且相互關聯的數據序列。分析時間序列的方法構成數據分析的一個重要領域&#xff0c;即時間序列分析。時間序列根據所研究的依據不同&#xff0c;可有不同的分類。1&#xff0e;按所研究的對象的多少分&#xff0…

Android之安卓8.0版本以上手機開啟熱點提示Caller already has an active LocalOnlyHotspot request

1 問題 在Android8.0手機開啟了熱點,關閉頁面再次打開熱點, /*** 開啟Android8.0版本手機以上的熱點,熱點名字和密碼都是隨機的。*/fun initWifiApGreaterThanEight(context: Context) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {var wifiManager:WifiMana…

JavaScript基礎和js概括

js內容概括&#xff1a; Html 結構化 CSS 樣式 JavaScript 行為交互 01.JavaScript基礎 02.JavaScript操作BOM對象 03.JavaScript操作DOM對象 ***** 04.JavaScript的面向對象 -------------------------------------- 05.jQuery (js) .css .js 06.jQuery選擇器 …

《看聊天記錄都學不會C語言?太菜了吧》(12)循環有多容易?你看一眼就懷...

若是大一學子或者是真心想學習剛入門的小伙伴可以私聊我&#xff0c;若你是真心學習可以送你書籍&#xff0c;指導你學習&#xff0c;給予你目標方向的學習路線&#xff0c;無套路&#xff0c;博客為證。 本系列文章將會以通俗易懂的對話方式進行教學&#xff0c;對話中將涵蓋…

***ECharts圖表入門和最佳實踐

ECharts數據圖表系統&#xff1f; 5分鐘上手&#xff01; 【ECharts簡介】 ECharts開源來自百度商業前端數據可視化團隊&#xff0c;基于html5 Canvas&#xff0c;是一個純Javascript圖表庫&#xff0c;提供直觀&#xff0c;生動&#xff0c;可交互&#xff0c;可個性化定制的數…

【經典回放】多種語言系列數據結構線性表之一:順序表

一、實驗任務描述 建立線性表的ADT后,編程完成: 1 用C語言完成一個順序表結構; 2 為順序表完成追加、刪除、插入、查找的功能; 3 建立一個鏈表的結點; 4 完成鏈表的追加、刪除、插入功能; 5* 用C#完成一個結點的類; 6* C#完成鏈表的追加、刪除、插入功能的類; 7* C#編寫…

原型繼承+原型鏈 + 對象繼承發展

一、原型繼承&#xff1a; &#xff11;、說起原型繼承&#xff0c;就要先由構造函數創造對象說起&#xff0c;首先了解構造函數內部基本原理&#xff1a; &#xff08;&#xff11;&#xff09;.在函數體最前面隱式的加上this {} &#xff08;&#xff12;&#xff09;.執行 …

Kotlin之?和!!最簡單的理解

一、? 1&#xff09;、?在聲明對象時&#xff0c;把它跟在類名后面&#xff0c;表示這個類允許為null var list: ArrayList<String>? null 2&#xff09;、調用對象時&#xff0c;把它跟在對象后面&#xff0c;表示如果為null程序就會視而不見&#xff0c;比如我們…

WPF|一個比較簡單帶點設計的登錄界面

閱讀目錄效果展示準備簡單說明 源碼結尾&#xff08;視頻及源碼倉庫&#xff09;1. 效果展示欣賞效果&#xff1a;2. 準備創建一個WPF工程&#xff0c;比如站長使用 .NET 7[1] 創建名為 Login5 的WPF項目。找一張圖片做為裝飾&#xff0c;放登錄表單左側&#xff1a;添加Nuget…

Android插件基礎之類加載器學習

記錄學習java 加載器學習所獲心得&#xff0c;逐步記錄了解java加載器的過程。為了知悉android 插件化的實現原理&#xff0c;從而需要從頭了解android加載apk&#xff0c;以及基礎的java類加載的加載過程情況&#xff0c;為方便記錄和記憶&#xff0c;故此將學習了解的過程記錄…

php多個文件上傳代碼,PHP單文件上傳類或多文件上傳類源碼

以下為引用的內容&#xff1a;php文件:代碼://如果收到表單傳來的參數&#xff0c;則進行上傳處理&#xff0c;否則顯示表單if(isset($_FILES[uploadinput])){//建目錄函數&#xff0c;其中參數$directoryName最后沒有"/"&#xff0c;//要是有的話&#xff0c;以/打散…

《看聊天記錄都學不會C語言?太菜了吧》(13)(9*9 乘法表)尋找電腦中的盲盒彩蛋

若是大一學子或者是真心想學習剛入門的小伙伴可以私聊我&#xff0c;若你是真心學習可以送你書籍&#xff0c;指導你學習&#xff0c;給予你目標方向的學習路線&#xff0c;無套路&#xff0c;博客為證。 本系列文章將會以通俗易懂的對話方式進行教學&#xff0c;對話中將涵蓋…

Fragment使用--文章集錦

android使用Fragment實現底部菜單使用show()和hide()來切換以保持Fragment狀態Android Fragment 真正的完全解析&#xff08;上&#xff09;Android Fragment實踐(一)糾正對Fragment Transaction BackStack的誤解多個Fragment 切換時不重新實例化Fragment詳解之四——管理Fragm…

Android之在在EditText的xml里面配置了相關屬性依然沒有顯示光標問題

1 問題 在EditText的xml里面配置了 android:cursorVisible"true" android:focusable"true" android:focusableInTouchMode"true" 依然沒有光標顯示 2 解決辦法 直接在代碼層控制&#xff0c;平且拉起鍵盤 fun showSoftInputFromWindow(activ…

【經典回放】多種語言系列數據結構線性表之二:鏈表

目錄 1 鏈表結構設計 2 簡單的鏈表測試 2 鏈表的組織和ADT設計 3 初始化有頭結點鏈表 4 有頭結點鏈表中追加一個結點(一行數據)