Jquery 控制div弹出框在点击对象附近

HTML:

<div>点击弹出:<input id="text"  /></div>

<div id="showDiv" style="display:none; background-color:#666666; width: 200px; height: 100px;font-size: 14px;color:#CC0033" >DIV弹出框</div>

JS:

点击输入框,在输入框下方显示弹出框,
offset().left和offset().top获取输入框的位置,然后动态定义弹出框显示位置

$(function() {
        
        $("#text").click(function(){
            var tt = $("#text");
            $("#showDiv").css({position:"absolute",'z-index':80,left:tt.offset().left,top:tt.offset().top+25});
            
            if($("#showDiv").is(':visible')){
                
                $("#showDiv").hide();
            }else{
                $("#showDiv").show();
            
            }
            
        });
        
    });    
is(':visible')和is(':hidden')都是判断对象是否可见。
is(':visible')可见的,返回true。
is(':hidden')不可见,返回true。
注:这个函数效率很低!我又在网上查了下,找到一个更好的getBoundingClientRect(),获取网页对象实际的top、bottom、left、right定位值,我们利用它计算对象的高度差,如果为0,即可认为element不可见。关键是,几乎所有浏览器都支持getBoundingClientRect。
实现 再次点击输入框,弹出框消失。

 

 

转载于:https://www.cnblogs.com/yunp07/p/3613143.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值