jQuery+CSS 實(shí)現(xiàn)隨滾動(dòng)條增減的汽水瓶中的液體效果
更新時(shí)間:2011年09月26日 15:17:32 作者:
一個(gè)很有意思的網(wǎng)站,那個(gè)網(wǎng)站是一家德國(guó)汽水公司的網(wǎng)站(德文神馬的),網(wǎng)站首頁(yè)有一個(gè)汽水瓶,汽水瓶里的水會(huì)隨著我們向下拉滾動(dòng)條而減少。
很有意思。小邪就跟著做了一個(gè)Demo,木有用插件,只掛了jQuery。
Demo 演示頁(yè)面
話說喝汽水的那個(gè)網(wǎng)站是用一個(gè)瓶子的圖片,分為瓶口、瓶身、吸管還有瓶底。在這些圖片中瓶子內(nèi)部都是透明的,所以我們可以在底下一層按 x 軸平鋪液體的圖片,當(dāng)然記得弄好吸管,吸管則是按照 y 軸平鋪。其他具體的請(qǐng)看代碼中注釋。
啊,對(duì)了,那家公司的地址在這里 - http://janploch.de/
body {background:#fff url(bg_site.png);margin:0;}
#juice, #juice .inner, #bottle, #bottle .footer, #bottle .content, #bottle .header, #mid .inner {margin:0 auto;}
/*
* #juice 加不加 margin:0 auto; 無(wú)所謂啦
* 因?yàn)?position:fixed; 了所以 margin:0 auto; 自然就失效了
* 因?yàn)?#bottle 無(wú)法準(zhǔn)確設(shè)置寬度,所以自然加 margin:0 auto; 也沒用了
* 嘿嘿,這些都是小邪的錯(cuò)誤
*
* #bottle .footer, #bottle .content, #bottle .header 這幾個(gè)
* 分別是瓶底、瓶身、瓶口幾個(gè)位置的圖片
* 剩下的 #juice .inner 和 #mid .inner 則分別
* 是居中按 x 軸平鋪的液體和居中按 y 軸平鋪的吸管咯
*/
#monitor {
position:fixed;
top:10px;
left:10px;
color:#f0f0f0;
z-index:999;
}
/*
* #monitor 則是左上角的提示文字區(qū)域,具體查看JS注釋部分
*/
#juice {
width:99%;
position:fixed;
top:2000px;
}
#juice .inner {
width:1165px;
background:url(juice.png) repeat-x;
height:2000px;
}
/*
* #juice 在外層設(shè)置為 position:fixed; width:99%;
* position:fixed; 的意思是絕對(duì)定位的元素,相對(duì)于瀏覽器窗口定位
* #juice .inner 在里層設(shè)置為 margin:0 auto; width:1165px;
* 這樣配合好就能做出既是居中又是不隨滾動(dòng)條移動(dòng)的效果
*/
#bottle {
width:99%;
text-align:center;
position:absolute;
top:0;
}
/*
* position:absolute; top:0;
* 這樣做因?yàn)榻^對(duì)定位的東西多了,防止妨礙到瓶體的位置
* text-align:center; 純蛋疼勿在意
*/
#bottle .header {
background:url(bottle_top.png) no-repeat;
width:1175px;
height:2648px;
}
#bottle .content {
background:url(content_bg.png) repeat-y;
height:500px;
width:1186px;
}
#bottle .footer {
background:url(bg_footer.png) no-repeat;
width:1184px;
height:567px;
}
/*
* 分別瓶子三部分,很簡(jiǎn)單的 o(* ̄▽ ̄*)ゞ
*/
#mid {
width:99%;
position:fixed;
z-index:-999;
}
/*
* 此處效果同 #juice,z-index:-999; 表示放到最底層
*/
#mid .inner {
width:92px;
height:2000px;
background:url(strohalm_mid.png) repeat-y;
}
/*
* #mid .inner 則是吸管的圖片設(shè)置
*/
</style>
<script type="text/javascript">
jQuery(document).ready(function($){
//記得在這段代碼前面掛上 jQuery 庫(kù)哈,忘記的童鞋拉出去切JJ一小時(shí)
$(window).scroll(function() {
//滾動(dòng)條觸發(fā)事件,目標(biāo)則是整個(gè)窗口,即此窗口的滾動(dòng)條
$("#monitor").html("scrollTop: "+$(window).scrollTop());
//在 #monitor 里面隨時(shí)監(jiān)視 $(window).scrollTop() 的值
if ($(window).scrollTop()<1108) $("#juice").css('top',490+815-$(window).scrollTop());
else $("#juice").css('top',$(window).scrollTop()/2900*580)
//$(window).scrollTop()<1108 則液體停止增加,并且隨滾動(dòng)條上拉而下移
//反之則按滾動(dòng)條滾動(dòng)的比例增減
//1108是液體應(yīng)該停止增加的時(shí)候,$(window).scrollTop()的值
//2900是頁(yè)面高度,580是窗口的部分高度
//490 815 什么的小邪才不知道是什么咧(其實(shí)是這家伙忘記了
//反正隨滾動(dòng)條上拉而遠(yuǎn)離窗口頂部啦
});
})
</script>
<div id="demo_menu" style="position:fixed;bottom:10px;left:10px;z-index:999;"><a style="color:#fff;" href="/">返回</a></div>
<div id="monitor" style="">scrollTop: 0</div>
<div id="juice"><div class="inner"></div></div>
<div id="mid"><div class="inner"></div></div>
<div id="bottle">
<div class="header"></div>
<div class="content"></div>
<div class="footer"></div>
</div>
二. 尾記:
總結(jié)一下,恩恩,這樣子是用于大家加深對(duì) jQuery 和設(shè)計(jì)中對(duì)視覺滴應(yīng)用滴理解(其實(shí)是小邪弄得自己蛋疼然后想拉上大家一起疼),理解完之后感覺無(wú)力的還是去用插件吧 (╯_╰) (小邪表示無(wú)力+1,這樣的確有點(diǎn)折騰人 (=_-) 的說)。嘿嘿嘿嘿嘿 o(* ̄▽ ̄*)ゞ。
演示代碼打包下載
Demo 演示頁(yè)面

話說喝汽水的那個(gè)網(wǎng)站是用一個(gè)瓶子的圖片,分為瓶口、瓶身、吸管還有瓶底。在這些圖片中瓶子內(nèi)部都是透明的,所以我們可以在底下一層按 x 軸平鋪液體的圖片,當(dāng)然記得弄好吸管,吸管則是按照 y 軸平鋪。其他具體的請(qǐng)看代碼中注釋。
啊,對(duì)了,那家公司的地址在這里 - http://janploch.de/

復(fù)制代碼 代碼如下:
body {background:#fff url(bg_site.png);margin:0;}
#juice, #juice .inner, #bottle, #bottle .footer, #bottle .content, #bottle .header, #mid .inner {margin:0 auto;}
/*
* #juice 加不加 margin:0 auto; 無(wú)所謂啦
* 因?yàn)?position:fixed; 了所以 margin:0 auto; 自然就失效了
* 因?yàn)?#bottle 無(wú)法準(zhǔn)確設(shè)置寬度,所以自然加 margin:0 auto; 也沒用了
* 嘿嘿,這些都是小邪的錯(cuò)誤
*
* #bottle .footer, #bottle .content, #bottle .header 這幾個(gè)
* 分別是瓶底、瓶身、瓶口幾個(gè)位置的圖片
* 剩下的 #juice .inner 和 #mid .inner 則分別
* 是居中按 x 軸平鋪的液體和居中按 y 軸平鋪的吸管咯
*/
#monitor {
position:fixed;
top:10px;
left:10px;
color:#f0f0f0;
z-index:999;
}
/*
* #monitor 則是左上角的提示文字區(qū)域,具體查看JS注釋部分
*/
#juice {
width:99%;
position:fixed;
top:2000px;
}
#juice .inner {
width:1165px;
background:url(juice.png) repeat-x;
height:2000px;
}
/*
* #juice 在外層設(shè)置為 position:fixed; width:99%;
* position:fixed; 的意思是絕對(duì)定位的元素,相對(duì)于瀏覽器窗口定位
* #juice .inner 在里層設(shè)置為 margin:0 auto; width:1165px;
* 這樣配合好就能做出既是居中又是不隨滾動(dòng)條移動(dòng)的效果
*/
#bottle {
width:99%;
text-align:center;
position:absolute;
top:0;
}
/*
* position:absolute; top:0;
* 這樣做因?yàn)榻^對(duì)定位的東西多了,防止妨礙到瓶體的位置
* text-align:center; 純蛋疼勿在意
*/
#bottle .header {
background:url(bottle_top.png) no-repeat;
width:1175px;
height:2648px;
}
#bottle .content {
background:url(content_bg.png) repeat-y;
height:500px;
width:1186px;
}
#bottle .footer {
background:url(bg_footer.png) no-repeat;
width:1184px;
height:567px;
}
/*
* 分別瓶子三部分,很簡(jiǎn)單的 o(* ̄▽ ̄*)ゞ
*/
#mid {
width:99%;
position:fixed;
z-index:-999;
}
/*
* 此處效果同 #juice,z-index:-999; 表示放到最底層
*/
#mid .inner {
width:92px;
height:2000px;
background:url(strohalm_mid.png) repeat-y;
}
/*
* #mid .inner 則是吸管的圖片設(shè)置
*/
</style>
<script type="text/javascript">
jQuery(document).ready(function($){
//記得在這段代碼前面掛上 jQuery 庫(kù)哈,忘記的童鞋拉出去切JJ一小時(shí)
$(window).scroll(function() {
//滾動(dòng)條觸發(fā)事件,目標(biāo)則是整個(gè)窗口,即此窗口的滾動(dòng)條
$("#monitor").html("scrollTop: "+$(window).scrollTop());
//在 #monitor 里面隨時(shí)監(jiān)視 $(window).scrollTop() 的值
if ($(window).scrollTop()<1108) $("#juice").css('top',490+815-$(window).scrollTop());
else $("#juice").css('top',$(window).scrollTop()/2900*580)
//$(window).scrollTop()<1108 則液體停止增加,并且隨滾動(dòng)條上拉而下移
//反之則按滾動(dòng)條滾動(dòng)的比例增減
//1108是液體應(yīng)該停止增加的時(shí)候,$(window).scrollTop()的值
//2900是頁(yè)面高度,580是窗口的部分高度
//490 815 什么的小邪才不知道是什么咧(其實(shí)是這家伙忘記了
//反正隨滾動(dòng)條上拉而遠(yuǎn)離窗口頂部啦
});
})
</script>
<div id="demo_menu" style="position:fixed;bottom:10px;left:10px;z-index:999;"><a style="color:#fff;" href="/">返回</a></div>
<div id="monitor" style="">scrollTop: 0</div>
<div id="juice"><div class="inner"></div></div>
<div id="mid"><div class="inner"></div></div>
<div id="bottle">
<div class="header"></div>
<div class="content"></div>
<div class="footer"></div>
</div>
二. 尾記:
總結(jié)一下,恩恩,這樣子是用于大家加深對(duì) jQuery 和設(shè)計(jì)中對(duì)視覺滴應(yīng)用滴理解(其實(shí)是小邪弄得自己蛋疼然后想拉上大家一起疼),理解完之后感覺無(wú)力的還是去用插件吧 (╯_╰) (小邪表示無(wú)力+1,這樣的確有點(diǎn)折騰人 (=_-) 的說)。嘿嘿嘿嘿嘿 o(* ̄▽ ̄*)ゞ。
演示代碼打包下載
相關(guān)文章
jQuery EasyUI Tab 選項(xiàng)卡問題小結(jié)
這篇文章主要介紹了jQuery EasyUI Tab 選項(xiàng)卡問題小結(jié),在項(xiàng)目開發(fā)階段很多朋友都遇到過此問題,其實(shí)解決辦法很簡(jiǎn)單的,下面小編給大家分享下問題原因及解決辦法,需要的朋友可以參考下2016-08-08
jQuery-Citys省市區(qū)三級(jí)菜單聯(lián)動(dòng)插件使用詳解
這篇文章主要為大家詳細(xì)介紹了jQuery-Citys省市區(qū)三級(jí)菜單聯(lián)動(dòng)插件使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
輕松學(xué)習(xí)jQuery插件EasyUI EasyUI實(shí)現(xiàn)拖動(dòng)基本操作
這篇文章主要幫大家輕松學(xué)習(xí)jQuery插件EasyUI,并利用EasyUI實(shí)現(xiàn)拖動(dòng)基本操作,文章并提供了一個(gè)學(xué)校課程表簡(jiǎn)單實(shí)例,感興趣的小伙伴們可以參考一下2015-11-11
jQuery函數(shù)的第二個(gè)參數(shù)獲取指定上下文中的DOM元素
這篇文章主要介紹了jQuery函數(shù)的第二個(gè)參數(shù)獲取指定上下文中的DOM元素,需要的朋友可以參考下2014-05-05
jQuery模擬html下拉多選框的原生實(shí)現(xiàn)方法示例
這篇文章主要介紹了jQuery模擬html下拉多選框的原生實(shí)現(xiàn)方法,結(jié)合完整實(shí)例形式分析了jQuery動(dòng)態(tài)操作頁(yè)面元素實(shí)現(xiàn)select下拉框效果的相關(guān)操作技巧,需要的朋友可以參考下2019-05-05
22點(diǎn)關(guān)于jquery性能優(yōu)化的建議
討論 jQuery 和 javascript 性能的文章并不罕見。然而,本文我計(jì)劃總結(jié)一些速度方面的技巧和我本人的一些建議,來(lái)提升你的 jQuery 和 javascript 代碼。好的代碼會(huì)帶來(lái)速度的提升??焖黉秩竞晚憫?yīng)意味著更好的用戶體驗(yàn)。2014-05-05
jquery validate 自定義驗(yàn)證方法介紹 日期驗(yàn)證
本篇文章主要是對(duì)jquery validate 自定義驗(yàn)證方法 日期驗(yàn)證進(jìn)行了介紹,需要的朋友可以過來(lái)參考下,希望對(duì)大家有所幫助2014-02-02

