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

首頁 > 編程 > JavaScript > 正文

js點(diǎn)擊出現(xiàn)懸浮窗效果不使用JQuery插件

2019-11-20 21:13:24
字體:
供稿:網(wǎng)友
JQuery有很多這樣的插件,但是我們公司不用jquery,沒有插件,所以我就試著自己寫,我也不知道別人是怎么寫的,純粹是按著自己的想法來的。

直接上代碼:
復(fù)制代碼 代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Demo</title>
<script type="text/javascript">
window.onload = function(){
var btn = document.getElementsByTagName('button')[0];
var flt = document.getElementsByTagName('div')[0];
btn.onclick = function(){
event.cancelBubble = true;
var x = btn.offsetLeft - 15 + 'px';
var y = btn.offsetTop - 100 + 'px';
flt.style.top = y;
flt.style.left = x;
flt.style.display = 'block';
}
document.onclick = function(){
flt.style.display = 'none';
}
}

</script>
<style type="text/css">
*{
margin: 0px;
padding: 0px;
}
div{
width: 60px;
height: 100px;
background: #33ccff;
display: none;
position: absolute;
}

div ul{
text-align: center;
}

div li{
list-style-type: none;
}
button{
top: 300px;
left: 400px;
position: absolute;
}
</style>
</head>
<body>
<button id="btn">Click</button>
<div>
<ul id="nav">
<li class="item1"><a href="">Demo 1</a></li>
<li class="item2"><a href="">Demo 2</a></li>
<li class="item3"><a href="">Demo 3</a></li>
<li class="item4"><a href="">Demo 4</a></li>
<li class="item5"><a href="">Demo 5</a></li>
</ul>
</div>
</body>
</html>

復(fù)制到本地就可以測試了。

這里要說一下cancelBubble這兩個(gè)東西。因?yàn)槲易龅男Ч屈c(diǎn)擊按鈕就顯示div,點(diǎn)擊頁面的任意位置div就消失,但javascript的冒泡機(jī)制是button獲得一個(gè)onclick事件后,往上冒泡,dom在獲得一個(gè)onclick事件,這樣的話就和讓div消失的onclick事件沖突了,所以需要event.cancelBubble = true;這行代碼來停止冒泡。大體就是這樣,代碼很簡單。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 商水县| 青海省| 白银市| 邮箱| 大庆市| 和政县| 富川| 双桥区| 蒙城县| 宝鸡市| 九江市| 乐东| 河津市| 韶山市| 读书| 溧水县| 阳东县| 安岳县| 四平市| 长沙县| 垫江县| 灵川县| 武汉市| 泗阳县| 杨浦区| 桃园市| 兴城市| 大埔区| 班戈县| 三台县| 临邑县| 星座| 清镇市| 大厂| 达拉特旗| 简阳市| 水富县| 水城县| 石首市| 阳信县| 固阳县|