发布网友 发布时间:2022-05-16 07:13
共2个回答
懂视网 时间:2022-05-16 11:34
在之前做项目的时候经常会在主页面上点击某个按钮,右侧弹出一个div输出对应内容的详细信息。此时,我是希望在鼠标点击弹出层外的时候关闭该弹出层,主要思想就是:找到鼠标点击的那个元素
判断这个元素是否在指定区域内,其实就是判断它的父元素是不是弹出层
如果不是就对弹出层进行hide,如果是就不进行任何操作
具体实现
该代码需要使用jQuery,代码如下:
$(document).mousedown(function(e){ if($(e.target).parent("#info").length==0){ $("#info").hide(); } }) $(document).mousedown(function(e){})
$(document)就是获取整个网页文档对象,类似于原生的window.ducument
mousedown是鼠标事件,是指当鼠标指针移动到元素上方并按下鼠标按键时,类似的事件还有:
mouseup:当在元素上放松鼠标按钮时
mouseover:当鼠标指针位于元素上方时
$(e.target)
$(e.target)表示获取点击事件的元素。
parent()
$(e.target).parent("#info").length是获取当前点击事件元素带有id为info的父元素。
热心网友 时间:2022-05-16 08:42
在body绑订一个事件,这个事件只把这个弹窗口关闭就行了,如果这个弹窗口弹出的时候才帮订这个事件。追问可以给一段代码示范吗,谢谢追答$(function(){
function bdclose(id){ //自定义一个函数这个函数只关闭弹的窗口,
$('body').click(funciton(){ //帮订body事件
dialogclose(id); //这个就是调用关闭弹窗口的函数
});
}
});
比如你在显示弹窗口