亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2016年02月19日 10:28:52   作者:吳統(tǒng)威  
彈出框在網(wǎng)站頁(yè)面中是必不可少的一部分,今天借助腳本之家平臺(tái)給大家分享使用js實(shí)現(xiàn)簡(jiǎn)單的彈出框效果,感興趣的朋友一起學(xué)習(xí)吧

彈出框在網(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)文章

最新評(píng)論