WordPress中鼠标悬停显示和隐藏评论及引用按钮的实现


Posted in Javascript onJanuary 12, 2016

根据鼠标悬停显示、隐藏,回复和引用按钮
思路及原理
原理嘛很简单,如果你阅读过一页或者两页甚至更多页 Jquery 手册的话,
那么下面的原理解释你肯定能看懂,否则请跳至代码实现区域阅读。
思路很简单,

将回复、引用按钮放置在你想要的地方,CSS 样式设置 display:none;
绑定Jquery中的hover动作到你想要鼠标悬停后显示按钮的区域
是不是很简单?要是我以前写博客肯定会就此结束,
好吧,既然授人鱼那么继续…….

特效的代码实现部分
回复、引用的HTML代码

      <div class="comment-act"><a href="#respond">回复</a> | <a href="#respond">引用</a></div>
回复、引用的CSS样式设置
.comment-act{display:none;}
Jquery( Javascript ) 代码部分
注:li.comment 是我每一条评论所在的区域
   $('li.comment').hover(//注1
 function(){
 $(this).find('div.comment-act').fadeIn(400);
 },
 function(){
 $(this).find('div.comment-act').fadeOut(400);
 });

特效的代码的加强、进阶扩展
Jquery 特效的制作往往会碰到这么一种情况,
就是有一些极端的用户,会不停的在两个有悬停动画特效的区域不停来回切换(搞测试?),
因为我们的特效显示一般都会设定一个显示时间,在这里我们设定了400毫秒,
很明显,用户的鼠标来回切换一次也就100毫秒左右,甚至更少,
不停的来回切换往往就会生成一个动画队列,即使你鼠标不动了,
特效还会按照你鼠标之前发生过的动作不停隐藏、显示,直至响应完你最后一次鼠标动作,
虽然我说的这种情况不太多见,但是如果我们的评论条数很多,
而访客又不停的上下滑动鼠标翻查内容,是不是很容易出现这种情况?
是不是很烦?
不但很烦,还会加重客户端浏览器负载,影响网站效率,更是不好的用户体验。
问题解决其实很简单,利用hover的回调函数参数终止动画队列,

$('li.comment').hover(//注1
 function(){
 $(this).find('div.comment-act').fadeIn(400);
 },
 function(){
 $(this).find('div.comment-act').fadeOut(400,function(){$(this).stop(true);});
 });

因为我们在移出鼠标的时候是想停止所有的动画显示,
所以我们在鼠标移出隐藏掉回复、引用按钮之后终止掉该区域的动画队列。
实测,目前为止MG12的博客未对此种情况做处理(懒?没必要?)。
你可以拿他的博客作为对比,呵呵!
注1:hover是一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。这是一个自定义的方法,
它为频繁使用的任务提供了一种“保持在其中”的状态。
当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。

显示、隐藏评论者信息
这个功能很多主题都有,旨在减小页面篇幅、提高用户体验,我的这个主题本来也是预留了这个功能,但是因为鄙人懒所以一直没有改造。最近这阵子小恙再加上本来也懒所以也一直没有折腾博客,觉得再不折腾折腾博客兴许就这么闲下来了。

望高手指正
JS代码如下:

var cmtinfo = jQuery('#cmtinfo');
if (cmtinfo.length>0){
var hideinfo = cmtinfo.find('#hide_author_info');
var showinfo = cmtinfo.find('#show_author_info');
var authorinfo = jQuery('#author_info');
authorinfo.hide();
showinfo.click(function(){jQuery(this).fadeOut(function(){hideinfo.fadeIn();});authorinfo.fadeIn();});
hideinfo.click(function(){jQuery(this).fadeOut(function(){showinfo.fadeIn();});authorinfo.fadeOut();});
}

#cmtinfo 是有信息的访客所显示访客新的一个 DIV

#hide_author_info、#show_author_info 一个是隐藏按钮一个是显示按钮

#author_info 是 #cmtinfo 的一个子 DIV
Javascript 相关文章推荐
使用IE6看老赵的博客 jQuery初探
Jan 17 Javascript
select标签模拟/美化方法采用JS外挂式插件
Apr 01 Javascript
display和visibility的区别示例介绍
Feb 26 Javascript
JavaScript中实现单体模式分享
Jan 29 Javascript
浅析bootstrap原理及优缺点
Mar 19 Javascript
tab栏切换原理
Mar 22 Javascript
jQuery实现div跟随鼠标移动
Aug 20 jQuery
jQuery实现表格隔行换色
Sep 01 jQuery
基于vue-router 多级路由redirect 重定向的问题
Sep 03 Javascript
微信小程序自定义底部导航带跳转功能
Nov 27 Javascript
微信小程序模板template简单用法示例
Dec 04 Javascript
微信小程序开发之转发分享功能
Oct 22 Javascript
WordPress中利用AJAX技术进行评论提交的实现示例
Jan 12 #Javascript
基于JavaScript实现div层跟随滚动条滑动
Jan 12 #Javascript
JavaScript继承模式粗探
Jan 12 #Javascript
轻松实现Bootstrap图片轮播
Apr 20 #Javascript
探析浏览器执行JavaScript脚本加载与代码执行顺序
Jan 12 #Javascript
学习JavaScript设计模式之策略模式
Jan 12 #Javascript
基于jQuery1.9版本如何判断浏览器版本类型
Jan 12 #Javascript
You might like
PHP+.htaccess实现全站静态HTML文件GZIP压缩传输(一)
2007/02/15 PHP
php htmlentities和htmlspecialchars 的区别
2008/08/18 PHP
PHP写日志的实现方法
2014/11/05 PHP
PHP中array_slice函数用法实例详解
2014/11/25 PHP
Yii把CGridView文本框换成下拉框的方法
2014/12/03 PHP
完美的php分页类
2017/10/24 PHP
laravel-admin表单提交隐藏一些数据,回调时获取数据的方法
2019/10/08 PHP
用脚本调用样式的几种方法
2006/12/09 Javascript
跟着Jquery API学Jquery之一 选择器
2010/04/07 Javascript
JS判断、校验MAC地址的2个实例
2014/05/05 Javascript
js中对函数设置默认参数值的3种方法
2015/10/23 Javascript
详解JavaScript函数
2015/12/01 Javascript
javascript基础语法学习笔记
2016/01/04 Javascript
javascript多物体运动实现方法分析
2016/01/08 Javascript
深入浅出 jQuery中的事件机制
2016/08/23 Javascript
微信小程序 图片上传实例详解
2017/05/05 Javascript
基于JavaScript实现无缝滚动效果
2017/07/21 Javascript
JS在Array数组中按指定位置删除或添加元素对象方法示例
2019/11/19 Javascript
JS 创建对象的模式实例小结
2020/04/28 Javascript
JavaScript实现HTML导航栏下拉菜单
2020/11/25 Javascript
vue+openlayers绘制省市边界线
2020/12/24 Vue.js
初步解析Python下的多进程编程
2015/04/28 Python
Python机器学习之K-Means聚类实现详解
2018/02/22 Python
Python3.6实现带有简单界面的有道翻译小程序
2019/04/16 Python
使用Matplotlib 绘制精美的数学图形例子
2019/12/13 Python
基于TensorBoard中graph模块图结构分析
2020/02/15 Python
美国最好的保健品打折网店:Swanson
2017/08/04 全球购物
英国最出名高街品牌:Forever Unique
2018/02/24 全球购物
英国家居用品和床上用品零售商:P&B Home
2020/01/16 全球购物
高中生校园生活自我评价
2013/09/19 职场文书
数控专业毕业生自荐信范文
2014/03/04 职场文书
百日安全活动总结
2014/05/04 职场文书
房产分割协议书范文
2014/11/21 职场文书
检讨书格式
2015/01/23 职场文书
2015年小学财务工作总结
2015/07/20 职场文书
vue判断按钮是否可以点击
2022/04/09 Vue.js