欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何創(chuàng)建一個JavaScript彈出DIV窗口層的效果

 更新時間:2013年09月25日 15:13:56   作者:  
我將用最通俗的語言和最簡潔的代碼給大家演示如何創(chuàng)建一個JavaScript彈出DIV窗口層的效果
在本教程中,我將用最通俗的語言和最簡潔的代碼給大家演示如何創(chuàng)建一個JavaScript彈出DIV窗口層的效果。

創(chuàng)建一個彈出DIV窗口可能是現(xiàn)在網(wǎng)站/網(wǎng)頁制作中最常碰到的問題之一。傳統(tǒng)的JavaScript彈窗已經(jīng)不適合目前網(wǎng)站的設(shè)計理念了,理由有二:首先,不友好——生硬的彈出對話框且伴隨著“哐”的一聲對用戶體驗(yàn)是個很大的挑戰(zhàn);其次,兼容性不夠強(qiáng)——有相當(dāng)多的瀏覽器屏蔽了這種JS的Alert()方法。于是,一個良好用戶體驗(yàn)的網(wǎng)站需要一種更合理的解決方案——使用很少的HTML代碼,很少的CSS代碼和幾行的JavaScript代碼來模擬瀏覽器默認(rèn)的彈出窗口(即替換掉默認(rèn)的Alert()界面和功能)。

實(shí)現(xiàn)原理:

首先,我們將彈出框中的內(nèi)容放置在一個特殊的DIV層中,然后默認(rèn)隱藏它(即初始不可見,使用CSS即可實(shí)現(xiàn))。當(dāng)用戶執(zhí)行某個動作時——比如點(diǎn)擊某個鏈接或者將鼠標(biāo)光標(biāo)移動到某個鏈接上——我們將之前設(shè)置好的隱藏層顯示在所有頁面元素的最上層(將使用JS操作實(shí)現(xiàn))。此外,我們還將在彈出DIV窗口中設(shè)置一個按鈕來執(zhí)行——當(dāng)用戶點(diǎn)擊此按鈕時關(guān)閉窗口的功能。

實(shí)現(xiàn)過程:

就如我上面提到的,我們首先需要創(chuàng)建一個特殊的DIV層,然后我們將彈出窗口的內(nèi)容放在這個DIV層里面。在這里,我們將其ID命名為“popupcontent ”以區(qū)別于其他DIV層。

<div id="popupcontent">這是一個DIV彈窗效果!</div>

彈出窗口的CSS修飾代碼:

接下來,讓我們給上面已創(chuàng)建好的這個DIV彈出層進(jìn)行CSS美化。其中最重要的幾個參數(shù)分別是:overflow(內(nèi)容溢出), visibility(可見性) 和position(定位方式)。同時我也給這個窗口效果添加了很多其他代碼,但這些只是用于美化,使這個窗口更絢麗。所以,我們最后定義的CSS代碼形如:
復(fù)制代碼 代碼如下:

#popupcontent{
position: absolute;
visibility: hidden;
overflow: hidden;
border:1px solid #CCC;
background-color:#F9F9F9;
border:1px solid #333;
padding:5px;
}

從上面CSS代碼中的紅色部分可以看出:這個DIV層初始默認(rèn)狀態(tài)是不可見的。

大家可以根據(jù)需要對以上代碼進(jìn)行美化,但請務(wù)必保留position,visibility,overflow三個屬性。

JavaScript代碼用于觸發(fā)和顯示彈出窗口:

這可能是本教程最重要最有趣的地方了。我們接下來會編寫2個過程函數(shù)分別用于顯示和隱藏上面那個DIV彈窗。當(dāng)然,這兩個函數(shù)之中會包含一些主體邏輯。

過程函數(shù)中需要順序包含的邏輯:

計算JavaScript彈出窗口在屏幕上的顯示位置(定位);
在彈出窗口中添加一個狀態(tài)欄(或按鈕),用于關(guān)閉打開狀態(tài)下的窗口;
顯示彈出窗口。

為了簡單起見,本例中我們設(shè)置的顯示位置是Top:200,Left:200。即以瀏覽器內(nèi)容框的左上角為坐標(biāo),向下偏移200PX,向左偏移200PX。

彈出窗口的大小我們可以在顯示函數(shù)的參數(shù)中進(jìn)行設(shè)置,包括兩個參數(shù):窗口長度和窗口寬度。

如果你需要將本例中的代碼進(jìn)行二次開發(fā),有個地方需要特別注意,那就是獲取彈出窗口DIV層的DOM對象,我們可以通過下面這個getElementById函數(shù)來獲取ID名為“Popcontent”的DOM對象。
復(fù)制代碼 代碼如下:

var popUp = document.getElementById("popupcontent");

在獲取這個(彈出窗口)DOM對象之后,我們可以在JS代碼中修改窗口的相對的位置和窗口大小。
復(fù)制代碼 代碼如下:

popUp.style.top = "200px";//窗口距離瀏覽器內(nèi)容區(qū)最上方的偏移值

popUp.style.left = "200px";//窗口距離瀏覽器內(nèi)容區(qū)最左邊的偏移值

popUp.style.width = w + "px";//窗口的寬度

popUp.style.height = h + "px";//窗口的高度

接下來,我們需要給窗口添加一個“關(guān)閉”按鈕,用于在窗口開啟狀態(tài)下關(guān)閉這個窗口。要完美的實(shí)現(xiàn)這一功能,首先我們需要聲明一個全局變量,用于存儲彈出窗口DIV中的內(nèi)容。這是因?yàn)椋绻阍谝粋€頁面中顯示多個內(nèi)容不同的彈出窗口,你不需要將按鈕重復(fù)的復(fù)制到這些DIV層中,這樣就簡化了行為邏輯:
復(fù)制代碼 代碼如下:

if (baseText == null) baseText = popUp.innerHTML;

popUp.innerHTML = baseText +

"<div id=\"statusbar\"><button onclick=\"hidePopup();\">Close window <button></div>";

最后一個需要注意的地方是這個“關(guān)閉”按鈕的定位問題。這個很容易實(shí)現(xiàn),設(shè)置一下這個按鈕對象的向上的空白邊即可(空白邊的數(shù)值設(shè)置成稍小于整個彈出窗口的DIV高度即可)。

至此,所有的行為邏輯講解完畢,最后的彈窗顯示函數(shù)的完整代碼如下:
復(fù)制代碼 代碼如下:

var baseText = null;

function showPopup(w,h){
var popUp = document.getElementById("popupcontent");
popUp.style.top = "200px";
popUp.style.left = "200px";
popUp.style.width = w + "px";
popUp.style.height = h + "px";
if (baseText == null) baseText = popUp.innerHTML;
popUp.innerHTML = baseText + "<div id=\"statusbar\"><button onclick=\"hidePopup();
\">Close window<button></div>";
var sbar = document.getElementById("statusbar");
sbar.style.marginTop = (parseInt(h)-40) + "px";
popUp.style.visibility = "visible";
}

隱藏彈出窗口:

隱藏彈出窗口的過程就相當(dāng)簡單了。只需要首先獲取彈出窗口那個DIV的DOM對象,然后將其屬性設(shè)置成“隱藏”即可。
復(fù)制代碼 代碼如下:

function hidePopup(){
var popUp = document.getElementById("popupcontent");
popUp.style.visibility = "hidden";
}

拓展HTML代碼最終實(shí)現(xiàn)彈窗效果:

我們需要做的就是在某個鏈接或者按鈕的對應(yīng)事件上添加JS函數(shù)“showPopup() ”即可。

比如,需要在鼠標(biāo)移動到某連接上時彈出窗口:

<a href="#" onmouseover="showPopup(300,200);" >Open popup</a>

需要在鼠標(biāo)點(diǎn)擊某個連接時彈出窗口:

<a href="#" onclick="showPopup(300,200);" >Open popup</a>

相關(guān)文章

  • JavaScript遞歸操作實(shí)例淺析

    JavaScript遞歸操作實(shí)例淺析

    這篇文章主要介紹了JavaScript遞歸操作,由一個階乘問題開始分析了遞歸操作的原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2016-10-10
  • 前端進(jìn)階之教你利用javascript存儲函數(shù)

    前端進(jìn)階之教你利用javascript存儲函數(shù)

    這篇文章主要給大家介紹了關(guān)于利用javascript存儲函數(shù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-11-11
  • js實(shí)現(xiàn)iframe跨頁面調(diào)用函數(shù)的方法

    js實(shí)現(xiàn)iframe跨頁面調(diào)用函數(shù)的方法

    這篇文章主要介紹了js實(shí)現(xiàn)iframe跨頁面調(diào)用函數(shù)的方法,實(shí)例展示了iframe中父頁面調(diào)用子頁面和子頁面調(diào)用父頁面的實(shí)現(xiàn)技巧,非常具有實(shí)用價值,需要的朋友可以參考下
    2014-12-12
  • 原生js的數(shù)組除重復(fù)簡單實(shí)例

    原生js的數(shù)組除重復(fù)簡單實(shí)例

    下面小編就為大家?guī)硪黄鷍s的數(shù)組除重復(fù)簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • layui問題之模擬table表格中的選中按鈕選中事件的方法

    layui問題之模擬table表格中的選中按鈕選中事件的方法

    今天小編就為大家分享一篇layui問題之模擬table表格中的選中按鈕選中事件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JS生成唯一id的多種解決方案(非常實(shí)用)

    JS生成唯一id的多種解決方案(非常實(shí)用)

    在項(xiàng)目開發(fā)中我們常需要給某些數(shù)據(jù)定義一個唯一標(biāo)識符,便于尋找關(guān)聯(lián),這篇文章主要給大家介紹了關(guān)于JS生成id的多種解決方案,文中介紹的方法都非常實(shí)用,需要的朋友可以參考下
    2023-10-10
  • JavaScript獲取對象key的幾種方法和區(qū)別

    JavaScript獲取對象key的幾種方法和區(qū)別

    這篇文章主要介紹了JavaScript獲取對象key的幾種方法和區(qū)別,下面文章更多的相關(guān)資料需要的小伙伴可以參考一下,希望對你有所幫助
    2022-03-03
  • Cocos2d實(shí)現(xiàn)刮刮卡效果

    Cocos2d實(shí)現(xiàn)刮刮卡效果

    這篇文章主要為大家詳細(xì)介紹了Cocos2d實(shí)現(xiàn)刮刮卡效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • JS封裝通過className獲取元素的函數(shù)示例

    JS封裝通過className獲取元素的函數(shù)示例

    這篇文章主要介紹了JS封裝通過className獲取元素的函數(shù),涉及javascript針對頁面元素屬性的遍歷與數(shù)組相關(guān)操作技巧,需要的朋友可以參考下
    2016-12-12
  • 基于IE下ul li 互相嵌套時的bug,排查,解決過程以及心得介紹

    基于IE下ul li 互相嵌套時的bug,排查,解決過程以及心得介紹

    昨天到今天上午都在查一個IE的bug,情形如下:通過異步請求獲取json數(shù)據(jù),然后拼接成html代碼,最后使用innerHTML類似方法插入到文檔流中。在chrome下和IE8\9下均表現(xiàn)正常。結(jié)果已進(jìn)入IE7,瀏覽器就崩潰,更別提IE6了,也是一副死給你看的樣子。于是我就把這個bug定位于IE6\7,其實(shí)這時候我已經(jīng)陷入了這個固定思維模式中,浪費(fèi)了不少時間
    2013-05-05

最新評論