• Jquerymenuaim流畅的菜单滑动体验


    参考网址:https://github.com/kamens/jQuery-menu-aim 

    Amazon网站分类导航的下拉菜单被使用得非常频繁,但你有没有注意过它的反应非常迅速?

    如此急速的用户体验,应该相当perfect了吧。

    jQuery-menu-aim

    menu-aim is a jQuery plugin for dropdown menus that can differentiate between a user trying hover over a dropdown item vs trying to navigate into a submenu's contents.

    menu-aim assumes that you are using a menu with submenus that expand to the menu's right. It will fire events when the user's mouse enters a new dropdown item and when that item is being intentionally hovered over.

    Amazon screenshot

    This problem is normally solved using timeouts and delays. menu-aim tries to solve this by detecting the direction of the user's mouse movement. This can make for quicker transitions when navigating up and down the menu. The experience is hopefully similar to amazon.com/'s "Shop by Department" dropdown.

    Use like so:

     $("#menu").menuAim({
         activate: $.noop,  // fired on row activation
         deactivate: $.noop,  // fired on row deactivation
     });
    

    ...to receive events when a menu's row has been purposefully (de)activated.

    The following options can be passed to menuAim. All functions execute with the relevant row's HTML element as the execution context ('this'):

     .menuAim({
         // Function to call when a row is purposefully activated. Use this
         // to show a submenu's content for the activated row.
         activate: function() {},
    
         // Function to call when a row is deactivated.
         deactivate: function() {},
    
         // Function to call when mouse enters a menu row. Entering a row
         // does not mean the row has been activated, as the user may be
         // mousing over to a submenu.
         enter: function() {},
    
         // Function to call when mouse exits a menu row.
         exit: function() {},
    
         // Selector for identifying which elements in the menu are rows
         // that can trigger the above events. Defaults to "> li".
         rowSelector: "> li",
    
         // You may have some menu rows that aren't submenus and therefore
         // shouldn't ever need to "activate." If so, filter submenu rows w/
         // this selector. Defaults to "*" (all elements).
         submenuSelector: "*"
     });
    

    Want an example to learn from?

    Check out example/example.html -- it has a working dropdown for you to play with:

    Example screenshot Play with the above example full of fun monkey pictures by opening example/example.html after downloading the repo.

  • 相关阅读:
    大数据学习之sqoop框架 25
    大数据学习之Flume框架 24
    大数据学习之Hive UDF及优化23
    大数据学习之HiveDDM数据操作语言22
    大数据学习之Hive数据仓库DDL数据定义语言21
    【MacOs】 SecureCRT设置linux终端显示颜色
    【MacOs】 VMware Fusion的NAT端口映射+静态IP
    【nginx】测试服务器配置内网项目转发
    【Linux】SSH连接linux时,长时间不操作就断开的解决方案
    【PHP】简易系统环境控制
  • 原文地址:https://www.cnblogs.com/boonya/p/2956635.html
Copyright © 2020-2023  润新知