ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript_javascript スキルに基づいてポップアップ ボックス効果を実装する

JavaScript_javascript スキルに基づいてポップアップ ボックス効果を実装する

WBOY
WBOYオリジナル
2016-05-16 15:14:472005ブラウズ

ポップアップ ボックスは Web サイトのページに不可欠な部分です。今日は、Script House プラットフォームを利用して、JS を使用して簡単なポップアップ ボックス効果を実現する方法を説明します。書いてあるので許してください!


まず、ポップアップ ボックスのコンポーネントを分析しましょう。単純なポップアップ ボックスは、見出し、コンテンツ、末尾に分かれています。先頭にはタイトルと閉じるボタンがあり、コンテンツにはグラフィック、メディア、 iframe、flash など、末尾はボタン (確認、キャンセルなど) です。この例では、主にポップアップ ボックスのコア部分を実装します。 >

<!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>
ポップアップ ボックスは、頭を押すと移動モードをオンにし、頭を離すと移動を禁止します。もちろん、ロジックは比較的単純です。

ここでは、移動の X 座標と Y 座標、移動の切り替えと禁止など、いくつかの変数を考えます。次に、onmousedown イベントと onmouseup イベントをタイトルに追加します。

onmousedown イベントは主に移動を開始します。

onmouseup イベントのロジックは主に、ポップアップ ボックスの動きを閉じて動きを無効にすることです。

次に、移動する必要があります。移動する必要がある場合は、ボディ内を移動する必要があります。そこで、onmousemove イベントをボディに追加します。ポップアップボックスの位置

これら 3 つのイベントは主に、CSS の位​​置属性と JS の Event イベントの属性の座標を組み合わせます。

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; // 是否开启移动
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("移动完成")
}
ポップアップ ボックスを移動した後、閉じるボタンに閉じるイベントを追加します。

//关闭 
var pop_close = pop.getElementsByClassName("pop-close")[0];
pop_close.onclick = function () {
pop.parentNode.removeChild(pop);
}
シンプルなポップアップ ボックスが実装されていますが、同じコード自体を最適化してカプセル化することができます。また、他の機能については自分で対処する必要がある場合があります (IE9 より前のバージョン)。 >


jsを使ったポップアップボックスエフェクトの紹介は以上です。お役に立てれば幸いです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。