java javascript模拟点击_纯JS实现点击区域外隐藏元素

【前言】

本文分享个常见的特效,点击其他区域即元素外时隐藏元素。

【主体】

主要利用event事件对象(事件源)和冒泡实现

demo

*{

margin: 0;

padding: 0;

}

.area{

position: fixed;

display: none;

left: 50%;

top: 50%;

transform: translate(-50%,-50%);

background-color: rgba(0,0,0,0.3);

}

.closeBtn{

width: 30px;

height: 30px;

position: absolute;

right: 0;

top: 0;

border: none;

outline: none;

}

.closeBtn:hover{

background-color: rgba(255,0,0,0.3);

color: white;

cursor: pointer;

}

登录

x

window.onload = function(){

function getByClass(classname){

return document.getElementsByClassName(classname);

}

var login = getByClass("login")[0];

var area = getByClass("area")[0];

var closeBtn = getByClass("closeBtn")[0];

// 显示

login.addEventListener("click",show,false);

function show(){

var client_width = document.body.clientWidth || document.documentElement.clientWidth;

var client_height = window.screen.height;

area.style.cssText = "display:block;width:"+client_width/2+"px;height:"+client_height/2+"px;"

}

// 关闭

closeBtn.addEventListener("click",close,false);

function close(){

area.style.cssText = "display:none";

}

// 点击其他位置关闭

document.onclick = function(event){

if(area.style.display == "block" && event.target.className != "login"){

if(event.target.className != area){

close();

}

}

}

//阻止冒泡

area.addEventListener("click",function(event){

var event = event || window.event;

var target = event.target || event.srcElement;

event.stopPropagation();

})

}

.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值