移动web端模拟hover效果

hover在PC端的用户体验中扮演着很重要的角色,那么移动web端我们又该如何增强这方面的用户体验呢?

下面我简单的在移动web端模拟了下hover的效果。

效果预览

请在移动端打开 源码

核心代码

//按钮点击效果$(document).on("touchstart", ".action-btn:not(.disable)", function (e) {    var $this = $(this);    var flag = true;    //遍历子类    $this.find("*").each(function () {        //查看有没有子类触发过active动作        if ($(this).hasClass("active")) flag = false;    });    //如果子类已经触发了active动作,父类则取消active触发操作    if (flag) $this.addClass("active");});$(document).on("touchmove", ".action-btn:not(.disable)", function (e) {    if ($(this).hasClass("active")) $(this).removeClass("active");});$(document).on("touchend", ".action-btn:not(.disable)", function (e) {    if ($(this).hasClass("active")) $(this).removeClass("active");});

代码是基于jQuery的

实现原理

基于touchstart、touchmove、touchend这三个事件,动态增删class。

默认只对含有action-btn class且不含有disable class的对象生效

使用方法

场景1

普通列表点击

    item1    item2    item3    item4    item5

只需要给列表添加上action-btn class以及提供相应的active class。

场景2

复杂列表点击

        item0        X    item1    item2    item3    item4

效果:点击列表时,触发列表点击效果,点击小叉时,触发小叉点击效果,小叉所在列不触发点击效果。

注意:无论小叉是否有点击效果(即active class),都需要给小叉添加action-btn class。即:当列和列的子元素都有点击逻辑的时候,都需要给它们添加action-btn class,否则会触发父类元素的点击效果。

其他

上面只是在移动web端对hover进行了简单的模拟,还有很多不足的地方。例如:当用户滑动列表时,滑动开始触点所在的列的点击效果会一闪而过。这个是因为点击效果的触发条件是touchstart。我也有尝试在触发touchstart时,延迟一定时间后判断是否触发过touchmove,没有触发的话才触发点击效果。但是在android上表现不佳,所以没有贴出类。

后续我会结合我的这篇文章10行代码搞定移动web端自定义tap事件中的tap事件进行效果优化。

文章有什么不对的地方,望大家指正。大家有什么好的实现方法,欢迎交流!

关键字:JavaScript, jquery

版权声明

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部