国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery

來源:懂視網 責編:小采 時間:2020-11-27 21:00:22
文檔

js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery

js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery:一、應用展示 關于層的智能浮動效果早在幾年前我就在國外的一些個人網站的垂直導航上見到了,現在似乎在國內一些商業網站上也屢見此效果,例如淘寶網的搜索結果頁的排序水平條,在默認狀態下,滾動條跟隨頁面滾動,如下: 隨著頁面向下滾動,當此水平條接觸
推薦度:
導讀js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery:一、應用展示 關于層的智能浮動效果早在幾年前我就在國外的一些個人網站的垂直導航上見到了,現在似乎在國內一些商業網站上也屢見此效果,例如淘寶網的搜索結果頁的排序水平條,在默認狀態下,滾動條跟隨頁面滾動,如下: 隨著頁面向下滾動,當此水平條接觸

一、應用展示
關于層的智能浮動效果早在幾年前我就在國外的一些個人網站的垂直導航上見到了,現在似乎在國內一些商業網站上也屢見此效果,例如淘寶網的搜索結果頁的排序水平條,在默認狀態下,滾動條跟隨頁面滾動,如下:

淘寶網搜索頁排序水平條 張鑫旭-鑫空間-鑫生活

隨著頁面向下滾動,當此水平條接觸瀏覽器的上邊緣時,水平條獨立出來,不跟隨滾動條滾動了,如下圖所示:
淘寶網搜索頁水平條 張鑫旭-鑫空間-鑫生活

類似的效果在新浪微博上也有:
新浪微博上智能定位層 張鑫旭-鑫空間-鑫生活

當頁面滾動,新動態提示開始要淡出瀏覽器窗口的時候,其浮動于瀏覽器窗口的最上沿顯示,如下圖所示:
新浪微博智能浮動層 張鑫旭-鑫空間-鑫生活

此效果實現原理其實很簡單,本文就將展示其實現。

二、實現原理

默認狀態就是默認狀態,什么事情也不用做,定位是absolute也好,static也好,都ok。關鍵是當瀏覽器滾動的時候,對象(要浮動的層)要移除瀏覽器界面視區的時候,修改其position屬性,讓其浮動在窗口的上沿顯示就可以了。最好的position屬性就是fixed了,可以在IE6+和其他瀏覽器下浮動層平滑固定定位,由于IE6前輩不支持fixed屬性,所以,后退一步,使用absolute屬性代替,但是會有副作用——滾動不平滑。但,這也是沒有辦法的事情了。

現在關鍵就是如何判斷當前層與瀏覽器窗口的上邊緣接觸呢?當浮動層與瀏覽器窗口上邊緣接觸的一瞬間,其頁面垂直偏移值與頁面的滾動高度其實是一致的,所以,用這個進行判斷就OK了,但是,如何獲得頁面上元素距離頁面的垂直距離呢?純粹的js代碼獲得此值還是比較麻煩的,好在JavaScript庫幫我們解決了這些工作,所以,我們的工作其實就很平坦,下面就將展示如何在jQuery庫以及MooTools庫下實現該效果。

三、jQuery下的層的智能浮動

方法代碼如下:
代碼如下:
$.fn.smartFloat = function() {
var position = function(element) {
var top = element.position().top, pos = element.css("position");
$(window).scroll(function() {
var scrolls = $(this).scrollTop();
if (scrolls > top) {
if (window.XMLHttpRequest) {
element.css({
position: "fixed",
top: 0
});
} else {
element.css({
top: scrolls
});
}
}else {
element.css({
position: "absolute",
top: top
});
}
});
};
return $(this).each(function() {
position($(this));
});
};

調用很簡單,直接一行代碼就ok了,例如下面:

$("#float").smartFloat();
妥妥兒的,就一小段綁定就實現了id為float的標簽有了智能浮動功能,效果描述就是:當id為float的元素在滾動的時候與瀏覽器上邊緣接觸時就不會再跟隨滾動條滾動了。

您可以狠狠地點擊這里:jQuery下的層的智能浮動demo

打開demo頁面,您會看到右側自詡羞澀的浮動層了,滾動頁面觀察效果:
jQuery智能浮動demo效果截圖 張鑫旭-鑫空間-鑫生活

四、MooTools下的層的智能浮動

與jQuery實現一樣,MooTools庫下也已經將此方法包裝了起來,代碼如下:
代碼如下:
var $smartFloat = function(elements) {
var position = function(element) {
var top = element.getPosition().y, pos = element.getStyle("position");
window.addEvent("scroll", function() {
var scrolls = this.getScroll().y;
if (scrolls > top) {
if (window.XMLHttpRequest) {
element.setStyles({
position: "fixed",
top: 0
});
} else {
element.setStyles({
top: scrolls
});
}
}else {
element.setStyles({
position: "absolute",
top: top
});
}
});
};
if ($type(elements) === "array") {
return elements.each(function(items) {
position(items);
});
} else if ($type(elements) === "element") {
position(elements);
}
};

使用也是非常的簡單,就一句代碼,同樣以id為float的標簽舉例,代碼如下:

$smartFloat($("float"));
您可以狠狠地點擊這里:MooTools下的層的智能浮動demo

滾動demo頁面的滾動條,當“羞澀”的浮動層與瀏覽器邊緣“接觸”的時候,就不再跟隨滾動條滾動了,如下圖所示:
層的智能浮動demo頁面 張鑫旭-鑫空間-鑫生活
來自張鑫旭

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery

js頁面滾動時層智能浮動定位實現(jQuery/MooTools)_jquery:一、應用展示 關于層的智能浮動效果早在幾年前我就在國外的一些個人網站的垂直導航上見到了,現在似乎在國內一些商業網站上也屢見此效果,例如淘寶網的搜索結果頁的排序水平條,在默認狀態下,滾動條跟隨頁面滾動,如下: 隨著頁面向下滾動,當此水平條接觸
推薦度:
標簽: js jQuery jquery實現
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 在线观看免费精品国产 | 自拍 欧美 在线 综合 另类 | 北条麻妃在线观看 | 亚洲另类网 | 四虎国产精品免费久久久 | 欧美成人禁片在线www | 久久一区二区三区精品 | 国产一级久久久久久毛片 | 成人一a毛片免费视频 | 欧美极品一区 | 国产欧美在线视频免费 | 91一区二区在线观看精品 | 暧暧视频免费 | 欧美激情影音先锋 | 国产精品第 | 国产免费一区二区 | 欧美人与禽zozzo性伦交 | 日韩视频一区二区在线观看 | 天堂一区二区三区精品 | 国产亚洲欧美一区二区 | 亚洲一区日韩二区欧美三区 | 久久久久久亚洲精品中文字幕 | 亚洲国产精品视频 | 成人免费一区二区三区 | 欧美久久久久久久一区二区三区 | 精品国产一区二区三区在线观看 | 国产精品久久久久久一级毛片 | 欧美日韩国产高清视频 | 免费视频国产 | 日韩欧美在线播放 | 亚洲 欧美 日韩 另类 | 免费精品国产日韩热久久 | 97在线视频免费 | 亚洲第一页中文字幕 | 国产在线视频一区 | 欧美日韩国产综合在线 | 99久久成人国产精品免费 | 欧美日韩在线高清 | 久久91精品国产91久久小草 | 欧美日韩亚洲高清不卡一区二区三区 | 亚洲欧美国产精品专区久久 |