hover在PC端的用户体验中扮演着很重要的角色,那么移动web端咱们又该如何加强这方面的用户体验呢?android
下面我简单的在移动web端模拟了下hover的效果。web
//按钮点击效果 $(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。this
默认只对含有action-btn class且不含有disable class的对象生效spa
普通列表点击code
<ul class="items"> <li class="action-btn">item1</li> <li class="action-btn active">item2</li> <li class="action-btn">item3</li> <li class="action-btn">item4</li> <li class="action-btn">item5</li> </ul>
只须要给列表添加上action-btn class以及提供相应的active class。对象
复杂列表点击 blog
<ul class="items"> <li class="action-btn"> item0 <span class="action-btn action-delete">X</span> </li> <li class="action-btn">item1</li> <li class="action-btn">item2</li> <li class="action-btn">item3</li> <li class="action-btn">item4</li> </ul>
效果:点击列表时,触发列表点击效果,点击小叉时,触发小叉点击效果,小叉所在列不触发点击效果。事件
注意:不管小叉是否有点击效果(即active class),都须要给小叉添加action-btn class。即:当列和列的子元素都有点击逻辑的时候,都须要给它们添加action-btn class,不然会触发父类元素的点击效果。
上面只是在移动web端对hover进行了简单的模拟,还有不少不足的地方。例如:当用户滑动列表时,滑动开始触点所在的列的点击效果会一闪而过。这个是由于点击效果的触发条件是touchstart。我也有尝试在触发touchstart时,延迟必定时间后判断是否触发过touchmove,没有触发的话才触发点击效果。可是在android上表现不佳,因此没有贴出类。
后续我会结合个人这篇文章10行代码搞定移动web端自定义tap事件中的tap事件进行效果优化。
文章有什么不对的地方,望你们指正。你们有什么好的实现方法,欢迎交流!