难度: ★★★☆
滚动菜单, 顾名思义是以滚动的方式显示和隐藏菜单的. 其实跟淡入淡出菜单和滚动菜单的原理是一样的, 前者是在触发事件的时候改变菜单的透明度, 而后者则是改变菜单的高度. 那为什么后者的处理难度会比前者高呢? 这正因为菜单高度的处理比透明度有更高的技巧要求. 下面我们就讨论一下该如何处理, 并难在什么地方.
这里只列出与淡入淡出菜单实现有所不同的地方, 对于以前说过的问题不再重复. 如有疑惑请先查看之前几篇相关的文章, 也欢迎在此留言交流.
这是效果演示
相关话题:
WordPress 导航菜单
二级导航菜单
淡出淡入导航菜单
滚动导航菜单
多级导航菜单
jQuery 导航菜单
点选式导航菜单 (待定话题)
作业分析:
正如前面所说, 滚动菜单的关键是对菜单高度的操作. 主要操作如下:
1. 菜单的初期化处理.
2. 展开和折叠菜单的处理方法.
3. 激活菜单的瞬间, 对菜单高度的处理.
实施操作:
初期化处理
为了处理更加灵活, 我们需要为它定义一个作为参数的滑动速度, 也就是每一个单位时间间隔, 菜单高度的改变幅度. 另外, 我们需要将菜单的初始高度定为 0.
| | // 速度来自参数, 默认没个时间单位移动 10px this.speed = speed || 10; // 设定初始化高度 this.util.setStyle(this.body, 'height', '0'); |
|
展开和折叠
展开和折叠的方法对应淡入淡出菜单的加强和减小不透明度, 只是处理对象不一样, 原理是一样的. 要注意将获取的高度转为整型再进行计算.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | expand: function() { // 获取当前高度, 并整型化 var height = parseInt(this.util.getStyle(this.body, 'height')); // 在时间单位内加上速度, 直到高度等于或超过最大高度 height += this.speed; if(height >= this.height) { height = this.height; // 取消循环调用 clearTimeout(this.tid); } // 重新设定菜单高度 this.util.setStyle(this.body, 'height', height + 'px'); } /** * 折叠菜单, 直到高度为 1 时隐藏菜单 */ collapse:function() { // 获取当前高度, 并整型化 var height = parseInt(this.util.getStyle(this.body, 'height')); // 在时间单位内减去速度, 直到高度等于或小于 1 height -= this.speed; if(height <= 1) { height = 1; // 隐藏菜单 this.util.setStyle(this.body, 'visibility', 'hidden'); // 取消循环调用 clearTimeout(this.tid); } // 重新设定菜单高度 this.util.setStyle(this.body, 'height', height + 'px'); } |
|
激活菜单的瞬间
十分十分十分重要, 滚动菜单中最具技巧, 也最有意思的一部分.
本程序中, 我对获取高度的方法进行了封装, 获取高度其实是返回元素的 offsetHeight. 按我的理解 (不知道是否正确), offsetHeight 会优先去获取 CSS 样式中的高度并返回, 当样式为空时才会去获取元素的实际高度. 所以有以下代码:
| | // 获得初始高度, 当鼠标在菜单标题上时获得展开时的初始高度, 当鼠标在菜单体上时取得菜单的实际高度 var initHeight = this.util.getStyle(this.body, 'height'); // 获得实际高度, 必须先清空样式的高度, 否则只会得到样式中的高度 this.util.setStyle(this.body, 'height', ''); this.height = this.util.getHeight(this.body); // 重新设定初始高度 this.util.setStyle(this.body, 'height', initHeight); |
|
演示主题:
以 WordPress 自带主题 default 为基础, 仅做学习参考使用, 修改过的文件有 header.php 和 style.css, 添加了文件 js/menu.js
下载主题: default_with_menubar_4.zip
下回预告:
下回继续讲讲点选式导航菜单, 也就是类似 Windows 窗体的菜单, 点下菜单即显示相应的菜单项, 直到菜单失去焦点. 只修改 JavaScript 代码实现, 可能会用到三个监听器: onclick, onmouseover 和 onblur.
(转自: WordPress 滚动导航菜单)
会员登录关闭
注册会员关闭