为了账号安全,请及时绑定邮箱和手机立即绑定

JS/jquery实现鼠标控制页面元素显隐

标签:
JQuery

最近因为公司网站要上一个活动广告横幅,当用户鼠标划过时显隐二维码。像这种鼠标事件控制页面元素显隐的情况,码农们会经常遇到,可以通过javascript或jquery代码实现,下面就几种常见需求一起归纳一下。

mouseout和mouseleave

这里需要特别注意mouseout与mouseleave的区别。我们通过下面代码示例来看一下:

<p  font-size:16px;"="">

<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>鼠标控制页面元素显隐</title><script class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="http://apps.bdimg.com/libs/jquery/1.11.3/jquery.min.js"></script><style>  #boxout,#boxleave{  width:250px;  height:100px;  padding-top:20px;  background-color:#cccccc;  float:left;  margin-left:30px;  }      #boxoutson,#boxleaveson{  width:200px;  height:50px;  background-color:yellow;  padding:0px auto;  margin:0px auto;  }</style></head><body>  <div id="boxout">    <div id="boxoutson">      第<span></span>此触发mouseout事件    </div>  </div>  <div id="boxleave">    <div id="boxleaveson">      第<span></span>此触发mouseleave事件    </div>  </div>  <script>x=0;y=0;  $("#boxout").mouseout(function() {          $("#boxout span").text(x+=1);      });    $("#boxleave").mouseleave(function() {    $("#boxleave span").text(y+=1);    });  </script></body></html>



fadeIn和fadeOut

前文实例中用的是show()和hide()方法,前台显隐效果瞬间完成,为了提高实际用户体验,这里我们介绍两位更友好的“朋友”,即fadeIn和fadeOut。


fadeIn:方法使用淡入效果来显示目标元素。

fadeOut:方法使用淡出效果来隐藏目标元素

这两个方法可以配置参数来控制速度,比如slow、normal、fast或指定毫秒数。

下面我们就show()、hide()与fadeIn()、fadeOut()的效果坐下对比,代码如下:


<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>鼠标控制页面元素显隐</title><script class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="http://apps.bdimg.com/libs/jquery/1.11.3/jquery.min.js"></script><style>  #box1,#box2{  width:250px;  height:100px;  padding-top:20px;  background-color:#cccccc;  float:left;  margin-left:30px;  }      #box1son,#box2son{  width:200px;  height:50px;  background-color:yellow;  padding:0px auto;  margin:0px auto;  }</style></head><body>  <div id="box1">    <div id="box1son">      <span>hide和show</span>    </div>  </div>  <div id="box2">    <div id="box2son">      <span>fadeIn和fadeOut</span>    </div>  </div>  <script>    $("#box1 span").hide();  $("#box1").mouseover(function() {         $("#box1 span").show();     }).mouseleave(function() {         $("#box1 span").hide();    });  $("#box2 span").hide();  $("#box2").mouseover(function() {          $("#box2 span").fadeIn("slow");      }).mouseleave(function() {          $("#box2 span").fadeOut("slow");      });  </script></body></html>


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消