国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

學習使用jquery iScroll.js移動端滾動條插件

2024-05-06 16:29:20
字體:
供稿:網(wǎng)友
這篇文章主要為大家詳細介紹了jquery iScroll.js移動端滾動條插件的使用方法,以及iScroll.js使用注意事項,感興趣的小伙伴們可以參考一下
 

大家在日常工作中最常用的插件是什么,jQurey?Lazyload?但是這些都是在PC端,但是在移動端最常用的插件莫過于iScroll了,iScroll到底是什么東西,應(yīng)該怎么用?iScroll是個很強大的插件,我也只是略懂皮毛,這里我們簡單的介紹一下。
iScroll的產(chǎn)生:

iScroll的產(chǎn)生完全是因為移動版webkit瀏覽器,例如在iPhone,Android 的移動設(shè)備上。
iScroll的使用方法:

iScroll的原理是外層有一個溢出隱藏(overflow:hidden;)的DOM,然后這個區(qū)域內(nèi)的第一個DOM結(jié)構(gòu)會被實例化,其包裹的內(nèi)容可以縱向或者橫向的滾動,所以在使用iScroll的時候,滾動元素要盡量的簡單,減少DOM個數(shù),減少嵌套,因為DOM結(jié)構(gòu)越是復(fù)雜iScroll運行起來就越是吃力,有可能會造成某些節(jié)點顯示不正常的情況。 所以,推薦使用的DOM結(jié)構(gòu)如下:

<div id="wrapper">//overflow:hidden; <ul> //只有第一個DOM結(jié)構(gòu)(ul)被實例化,這個DOM可以縱向或者橫向的滾動, //多出的內(nèi)容會被wrapper的樣式hidden。  <li>1</li>  <li>2</li>  <li>3</li> </ul></div>

注意:再次重申,只有wrapper里的第一個子元素(ul)才可以被實例化滾動,并且要結(jié)合外層的DOM(wrapper)才能實現(xiàn)滾動。
如果 wrapper中有多個ul怎么辦?很簡單,記住那句話,只有wrapper里的第一個子元素(ul)才可以被實例化滾動:

<div id="wrapper">//overflow:hidden; <div id="first">  //只有第一個DOM結(jié)構(gòu)(ul)被實例化,這個DOM可以縱向或者橫向的滾動,  //多出的內(nèi)容會被wrapper的樣式hidden  <ul>   <li>1</li>   <li>2</li>   <li>3</li>  </ul>  <ul>   <li>4</li>   <li>5</li>   <li>6</li>  </ul> </div></div>

看到了吧,只有first會被實例化。 注意:這里第一個DOM結(jié)構(gòu)的ID(first)可以不寫,我只是為了方便大家識別才寫了個ID,但是最外層的ID(wrapper)一定要寫,因為在JS實例化的時候需要填寫這個ID:

var myScroll = new iScroll("wrapper");

iScroll應(yīng)該如何實例化

既然說道了實例化,我們應(yīng)該在什么時候?qū)嵗???jù)說實例化的方法有很多,但是我沒用過,我只說一種:
(1)在HTML(uw3c.html)頁面底部(body之后html之前)加載iscroll.js與當前頁面的uw3c.js,這樣能確保HTML的DOM結(jié)構(gòu)能加載出來。
(2)在JS插入頁面DOM結(jié)構(gòu)和數(shù)據(jù)之前實例化iScroll,也就是在JS的最開始實例化,因為之后可能會使用JS來插入DOM或者數(shù)據(jù),這樣以來能確保在插入數(shù)據(jù)之前iScroll已經(jīng)實例化了。

HTML://HTML結(jié)構(gòu)

<html > <body>  ...code... </body>  //插入iscroll.js文件 <script type="text/javascript" src="js/iscroll.js" > </script > //插入本頁面JS文件 <script type="text/javascript" src="js/uw3c.js" > </script ></html>

 JS://JS文件內(nèi)容

var myscroll; function iscroll(data){  //實例化iScroll  myscroll=new iScroll("wrapper");  pageData(data); } function pageData(obj){  $("body").html(obj);  myscroll.refresh();//當DOM結(jié)構(gòu)發(fā)生變化的時候,需要刷新iScroll } iscroll("<div>pagedata</div>");

iScroll中的參數(shù):

在實例化iScroll的時候,可以傳入兩個參數(shù),第一個參數(shù)是實例化的外層的DOM的ID,第二個參數(shù)是iScroll執(zhí)行方法的對象:

var myscroll=new iScroll("wrapper",{hScrollbar:false});或者var opts = {    vScroll:false,//禁止垂直滾動    snap:true,//執(zhí)行傳送帶效果    hScrollbar:false//隱藏水平方向上的滾動條   };var myscroll = new iScroll("wrapper",opts);

第二個參數(shù)內(nèi)容如下,這個參數(shù)會控制iScroll的效果:

hScroll  false 禁止橫向滾動 true橫向滾動 默認為truevScroll  false 禁止垂直滾動 true垂直滾動 默認為truehScrollbar  false隱藏水平方向上的滾動條vScrollbar  false 隱藏垂直方向上的滾動條fadeScrollbar false 指定在無漸隱效果時隱藏滾動條hideScrollbar 在沒有用戶交互時隱藏滾動條 默認為truebounce   啟用或禁用邊界的反彈,默認為truemomentum  啟用或禁用慣性,默認為true,此參數(shù)在你想要保存資源的時候非常有用lockDirection false取消拖動方向的鎖定,true拖動只能在一個方向上(up/down 或者left/right)

iScroll中的方法:

當然在第二個參數(shù)中,也有一些方法可以執(zhí)行:
(1)scrollTo(x, y, time, relative)方法:傳入4個參數(shù):X軸滾動距離,Y軸滾動距離,效果時間,是否相對當前位置。所以例如:

//在200毫秒的時間內(nèi),Y軸向上滾動100像素;uw3c.scrollTo(0, -100, 200)//在200毫秒的時間內(nèi),相對于當前位置,X軸向左滾動100像素;uw3c.scrollTo(-100, 0, 200, true)

(2)refresh()方法:在DOM結(jié)構(gòu)發(fā)生改變之后,需要刷新iScroll,否則滾動插件會實例化的不準確:

uw3c.refresh();//刷新iScroll

(3)onPosChange,有沒有一個方法能返回位置的變化?你可以查詢一下自己所用的iScroll中有沒有onPosChange方法:

onPosChange:function(x,y){ if(y < -200){  //如果Y周向上滾動200像素,$("#uw3c")就顯示,否則就隱藏。  $("#uw3c").show(); }else{  $("#uw3c").hide(); }}

(4)onScrollEnd:滾動結(jié)束時執(zhí)行的事件,如果想在滾動結(jié)束時出發(fā)摸個事件,這個方法就拍上用處了:

//滾動結(jié)束后,執(zhí)行的方法,滾動后會出現(xiàn)提示框alert("uw3c.com")onScrollEnd:function(){ alert("uw3c.com");}

(5)onRefresh:在DOM結(jié)構(gòu)發(fā)生改變之后,需要刷新iScroll,否則滾動插件會實例化的不準確,onRefresh是刷新完iScroll會執(zhí)行的方法。
(6)onBeforeScrollStart:開始滾動前的時間回調(diào),默認是阻止瀏覽器默認行為 。
(7)onScrollStart:開始滾動的回調(diào)。
(8)onBeforeScrollMove:在內(nèi)容移動前的回調(diào)。
(9)onScrollMove:內(nèi)容移動的回調(diào)。
(10)onBeforeScrollEnd:在滾動結(jié)束前的回調(diào)。
(11)onTouchEnd:手離開屏幕后的回調(diào)。
(12)onDestroy:銷毀實例的回調(diào)。

以上就是本文的全部內(nèi)容,希望對大家熟練使用iScroll.js移動端滾動條插件有所幫助。



注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉川市| 获嘉县| 博白县| 咸宁市| 绩溪县| 裕民县| 东台市| 赤水市| 纳雍县| 郯城县| 平舆县| 丹阳市| 宁蒗| 上蔡县| 灵石县| 华蓥市| 新营市| 德州市| 临清市| 长丰县| 南宁市| 东乡族自治县| 卫辉市| 巴马| 枞阳县| 康保县| 承德市| 永新县| 长岛县| 马鞍山市| 大港区| 会泽县| 张家口市| 冕宁县| 昌平区| 太湖县| 南木林县| 阿克| 鱼台县| 竹溪县| 健康|