基于JavaScript實(shí)現(xiàn)彈出框效果
彈出框在網(wǎng)站頁(yè)面中是必不可少的一部分,今天借助腳本之家平臺(tái)給大家分享使用js實(shí)現(xiàn)簡(jiǎn)單的彈出框效果,本文寫不好,還請(qǐng)見諒!
首先我們來(lái)分析彈出框的部件.簡(jiǎn)單彈出框分為頭,內(nèi)容,尾部. 頭部中有標(biāo)題和關(guān)閉按鈕,內(nèi)容就可以圖文,媒體,iframe,flash等等,尾部就是按鈕(確認(rèn),取消等等),這個(gè)例子尾部我就不加入按鈕了,這個(gè)例子主要是實(shí)現(xiàn)彈出框的核心部分.
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style> body, div{ padding: 0; margin: 0; } html, body { width: 100%; height: 100%; } a { text-decoration: none; } .pop { border-radius: 5px; background-color: #fff; border: #eee 1px solid; position: absolute; width: 350px; left: 35%; top: 25%; } .pop-title { background-image: linear-gradient(#eee,#efefef); position: relative; cursor: pointer; } .pop-title h3,.pop-title a{ display: inline-block; } .pop-title h3{ font-size: 14px; margin: 0; padding: 5px; } .pop-title a { position: absolute; top: 5px; right: 5px; } .pop-content { padding: 10px; } </style> </head> <body> <div> <div> <h3>消息</h3> <a href="javascript:;">X</a> </div> <div> 彈出框已顯示 </div> <div></div> </div> </body> </html>
彈出框,在頭部按下的時(shí)候,開啟移動(dòng)模式,在頭部松開的時(shí)候就禁止移動(dòng).其實(shí)就這么一句的意思. 當(dāng)然邏輯也是比較簡(jiǎn)單的.
這里我們就可能想到了幾個(gè)變量,移動(dòng)的X,Y坐標(biāo),移動(dòng)的開關(guān)和禁止. 然后就是給title加入onmousedown 和 onmouseup事件.
onmousedown事件中主要是開啟移動(dòng).
onmouseup 事件中邏輯主要是關(guān)閉移動(dòng),禁止移動(dòng)彈出框.
接著需要移動(dòng),而移動(dòng)需要時(shí)在某個(gè)范圍內(nèi)移動(dòng).這里我們是在body里面移動(dòng). 所以給body加入onmousemove事件. 這里面做的事情就是移動(dòng)彈出框的位置處理.
在這三個(gè)事件中主要是配合了CSS中的position屬性和JS中的Event事件中的屬性的坐標(biāo).
var pop = document.getElementsByClassName("pop")[0]; var pop_title = pop.getElementsByClassName("pop-title")[0]; var bd = document.body; var x = 0; var y = 0; var ismove = false; // 是否開啟移動(dòng) var downx = 30; var downy = 30; pop_title.onmousedown = function (e) { x = e.pageX; y = e.pageY; downx = e.offsetX; downy = e.offsetY; ismove = true; } bd.onmousemove = function (e) { if (ismove) { var cx = e.pageX - downx; var cy = e.pageY - downy; pop.style.left = cx + "px"; pop.style.top = cy + "px"; x = e.x; y = e.y; } e.preventDefault(); } pop_title.onmouseup = function (e) { x = e.pageX; y = e.pageY; ismove = false; console.log("移動(dòng)完成") }
移動(dòng)彈出框完成后,我們給關(guān)閉按鈕加入關(guān)閉事件.
//關(guān)閉 var pop_close = pop.getElementsByClassName("pop-close")[0]; pop_close.onclick = function () { pop.parentNode.removeChild(pop); }
好了,簡(jiǎn)單的彈出框就實(shí)現(xiàn)了.同樣代碼自己可以優(yōu)化封裝,加入其它的功能.兼容性問(wèn)題可能需要自己去處理一下(IE9以前的版本).
js實(shí)現(xiàn)彈出框效果就給大家介紹這么多,希望對(duì)大家有所幫助!
相關(guān)文章
基于構(gòu)造函數(shù)的五種繼承方法小結(jié)
下面小編就為大家?guī)?lái)一篇基于構(gòu)造函數(shù)的五種繼承方法小結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07微信小程序?qū)崿F(xiàn)多選刪除列表數(shù)據(jù)功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)多選刪除列表數(shù)據(jù)功能,涉及微信小程序列表數(shù)據(jù)讀取、顯示、刪除等相關(guān)操作技巧,需要的朋友可以參考下2019-01-01關(guān)于編寫性能高效的javascript事件的技術(shù)
這篇文章主要介紹了關(guān)于編寫性能高效的javascript事件的技術(shù) ,需要的朋友可以參考下2014-11-11js獲取對(duì)象,數(shù)組所有屬性鍵值(key)和對(duì)應(yīng)值(value)的方法示例
這篇文章主要介紹了js獲取對(duì)象,數(shù)組所有屬性鍵值(key)和對(duì)應(yīng)值(value)的方法,涉及javascript對(duì)于對(duì)象、數(shù)組鍵名與鍵值遍歷相關(guān)操作技巧,需要的朋友可以參考下2019-06-06微信小程序textarea層級(jí)過(guò)高(蓋住其他元素)問(wèn)題的解決辦法
這篇文章主要給大家介紹了關(guān)于微信小程序textarea層級(jí)過(guò)高(蓋住其他元素)問(wèn)題的解決辦法,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03