国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

基于JavaScript實(shí)現(xiàn)彈出框效果

2019-11-20 10:33:58
字體:
供稿:網(wǎng)友

彈出框在網(wǎng)站頁面中是必不可少的一部分,今天借助武林網(wǎng)平臺(tái)給大家分享使用js實(shí)現(xià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)然邏輯也是比較簡單的.

這里我們就可能想到了幾個(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);}

好了,簡單的彈出框就實(shí)現(xiàn)了.同樣代碼自己可以優(yōu)化封裝,加入其它的功能.兼容性問題可能需要自己去處理一下(IE9以前的版本).

 

js實(shí)現(xiàn)彈出框效果就給大家介紹這么多,希望對大家有所幫助!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 比如县| 赤城县| 淄博市| 通化市| 唐山市| 黄大仙区| 航空| 六枝特区| 泽州县| 彭山县| 洪湖市| 固阳县| 新化县| 正蓝旗| 肥东县| 浦城县| 天长市| 桐梓县| 林西县| 北宁市| 锡林郭勒盟| 望奎县| 南开区| 桑日县| 镇平县| 兴山县| 武邑县| 浮山县| 西青区| 宜都市| 中西区| 鱼台县| 怀集县| 苗栗市| 松溪县| 绩溪县| 三河市| 英吉沙县| 任丘市| 乐至县| 五指山市|