用JS實(shí)現(xiàn)網(wǎng)頁(yè)元素陰影效果的研究總結(jié)
更新時(shí)間:2007年08月19日 12:27:43 作者:
前兩天由于一個(gè)小項(xiàng)目想為一元素添加一個(gè)陰影效果,但是記得看過(guò)某高人寫(xiě)的"用Div/CSS模擬陰影效果"文章,現(xiàn)在還有一點(diǎn)印象,其思路很簡(jiǎn)單,主要是利用幾個(gè)層的定位偏移來(lái)實(shí)現(xiàn)的陰影特效,于是偶就想能不能封裝成一個(gè)js函數(shù),方便在每個(gè)html對(duì)象上調(diào)用.
開(kāi)始偶以為很簡(jiǎn)單,但實(shí)現(xiàn)過(guò)程中確遇到了很多問(wèn)題,其中最嚴(yán)重的就是瀏覽器的兼容問(wèn)題,整整耗了偶整個(gè)晚上加半個(gè)通宵的時(shí)間才搞定,汗呢!不過(guò)從這個(gè)小東西讓我對(duì)js及一些瀏覽器之間的差異及解決辦法有了更多更深刻的認(rèn)識(shí).
總結(jié)于此,以備以后查看方便!
代碼如下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
設(shè)計(jì)的主題思路是:
對(duì)于需要添加陰影的元素:
IE/NS:創(chuàng)建一個(gè)與元素大小相同位置相同的層,并利用偏移的方法使該層實(shí)現(xiàn)陰影,然后根據(jù)對(duì)元素的絕對(duì)位置判斷將層定位到相同的位置并設(shè)置z-index=-1;從而實(shí)現(xiàn)陰影效果.
FF/Opear:思路同上,但因?yàn)镕F/Opear不支持z-index:-1,所以必須通過(guò)將原來(lái)元素的z-index設(shè)為大于0的值(需要將元素設(shè)為絕對(duì)定位)從而達(dá)到覆蓋陰影層的效果,因?yàn)橐O(shè)置z-index,必須將元素設(shè)為絕對(duì)定位,因此這里就比較麻煩了,偶的解決辦法是先克隆一個(gè)元素完全相同的內(nèi)容,并將其設(shè)為隱藏(使用visibility:hidden)但仍然占位,然后放到原元素的位置,而把原元素設(shè)為絕對(duì)定位并設(shè)定z-index的值大于0.
在制作過(guò)程中遇到很多問(wèn)題,其中主要問(wèn)題有:
1,style.cssText屬性只有除opera外的瀏覽器才支持,
2,offsetleft和offsetTop在IE/Opear和FF及NS中解釋不同.
(還包括一些不同瀏覽器出現(xiàn)的小bug,解決辦法見(jiàn)上篇日志)
不過(guò)好在都一一解決了!現(xiàn)在能兼容大多數(shù)瀏覽器的新版本.偶在IE6.0,FF2.0,NS8.1,Opear9.0下測(cè)試通過(guò)
開(kāi)始偶以為很簡(jiǎn)單,但實(shí)現(xiàn)過(guò)程中確遇到了很多問(wèn)題,其中最嚴(yán)重的就是瀏覽器的兼容問(wèn)題,整整耗了偶整個(gè)晚上加半個(gè)通宵的時(shí)間才搞定,汗呢!不過(guò)從這個(gè)小東西讓我對(duì)js及一些瀏覽器之間的差異及解決辦法有了更多更深刻的認(rèn)識(shí).
總結(jié)于此,以備以后查看方便!
代碼如下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
設(shè)計(jì)的主題思路是:
對(duì)于需要添加陰影的元素:
IE/NS:創(chuàng)建一個(gè)與元素大小相同位置相同的層,并利用偏移的方法使該層實(shí)現(xiàn)陰影,然后根據(jù)對(duì)元素的絕對(duì)位置判斷將層定位到相同的位置并設(shè)置z-index=-1;從而實(shí)現(xiàn)陰影效果.
FF/Opear:思路同上,但因?yàn)镕F/Opear不支持z-index:-1,所以必須通過(guò)將原來(lái)元素的z-index設(shè)為大于0的值(需要將元素設(shè)為絕對(duì)定位)從而達(dá)到覆蓋陰影層的效果,因?yàn)橐O(shè)置z-index,必須將元素設(shè)為絕對(duì)定位,因此這里就比較麻煩了,偶的解決辦法是先克隆一個(gè)元素完全相同的內(nèi)容,并將其設(shè)為隱藏(使用visibility:hidden)但仍然占位,然后放到原元素的位置,而把原元素設(shè)為絕對(duì)定位并設(shè)定z-index的值大于0.
在制作過(guò)程中遇到很多問(wèn)題,其中主要問(wèn)題有:
1,style.cssText屬性只有除opera外的瀏覽器才支持,
2,offsetleft和offsetTop在IE/Opear和FF及NS中解釋不同.
(還包括一些不同瀏覽器出現(xiàn)的小bug,解決辦法見(jiàn)上篇日志)
不過(guò)好在都一一解決了!現(xiàn)在能兼容大多數(shù)瀏覽器的新版本.偶在IE6.0,FF2.0,NS8.1,Opear9.0下測(cè)試通過(guò)
您可能感興趣的文章:
- JSP實(shí)現(xiàn)彈出登陸框以及陰影效果
- WebGL three.js學(xué)習(xí)筆記之陰影與實(shí)現(xiàn)物體的動(dòng)畫(huà)效果
- 利用Three.js如何實(shí)現(xiàn)陰影效果實(shí)例代碼
- js當(dāng)前頁(yè)面登錄注冊(cè)框,固定div,底層陰影的實(shí)例代碼
- JS當(dāng)前頁(yè)面登錄注冊(cè)框,固定DIV,底層陰影的實(shí)例代碼
- js 實(shí)現(xiàn)無(wú)干擾陰影效果 簡(jiǎn)單好用(附文件下載)
- Div+Js實(shí)現(xiàn)的帶陰影菜單 微軟以前網(wǎng)站曾用過(guò)
- JavaScript canvas實(shí)現(xiàn)帶有陰影的圖形和文字
相關(guān)文章
javascript小組件 原生table排序表格腳本(兼容ie firefox opera chrome)
javascript小組件 原生table排序表格腳本 兼容ie firefox opera chrome,需要的朋友可以參考下2012-07-07js判斷文件格式及大小的簡(jiǎn)單實(shí)例(必看)
下面小編就為大家?guī)?lái)一篇js判斷文件格式及大小的簡(jiǎn)單實(shí)例(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10js querySelector和getElementById通過(guò)id獲取元素的區(qū)別
這是sina同事xiaoniu發(fā)現(xiàn)的,querySelector和getElementById通過(guò)id獲取元素的區(qū)別2012-04-04javascript教程:關(guān)于if簡(jiǎn)寫(xiě)語(yǔ)句優(yōu)化的方法
這篇文章主要介紹了js中if簡(jiǎn)寫(xiě)語(yǔ)句優(yōu)化的方法,需要的朋友可以參考下2014-05-05js實(shí)現(xiàn)一個(gè)省市區(qū)三級(jí)聯(lián)動(dòng)選擇框代碼分享
省市區(qū)三級(jí)聯(lián)動(dòng)在填寫(xiě)表單時(shí)有關(guān)地址這一塊顯得尤為重要,直接提高了用戶的填寫(xiě)速度與準(zhǔn)確度,接下來(lái)本文使用js代碼實(shí)現(xiàn)一個(gè),感興趣的你可以參考下希望可以幫助到你2013-03-03