滑动式折叠菜单 - Slashdot's Menu
- <script type="text/javascript">
- function SDMenu(id) {
- if (!document.getElementById || !document.getElementsByTagName)
- return false;
- this.menu = document.getElementById(id);
- this.submenus = this.menu.getElementsByTagName("div");
- this.remember = true;
- this.speed = 3;
- this.markCurrent = true;
- this.oneSmOnly = false;
- }
- SDMenu.prototype.init = function() {
- var mainInstance = this;
- for (var i = 0; i < this.submenus.length; i++)
- this.submenus[i].getElementsByTagName("span")[0].onclick = function() {
- mainInstance.toggleMenu(this.parentNode);
- };
- if (this.markCurrent) {
- var links = this.menu.getElementsByTagName("a");
- for (var i = 0; i < links.length; i++)
- if (links[i].href == document.location.href) {
- links[i].className = "current";
- break;
- }
- }
- if (this.remember) {
- var regex = new RegExp("sdmenu_" + encodeURIComponent(this.menu.id) + "=([01]+)");
- var match = regex.exec(document.cookie);
- if (match) {
- var states = match[1].split("");
- for (var i = 0; i < states.length; i++)
- this.submenus[i].className = (states[i] == 0 ? "collapsed" : "");
- }
- }
- };
- SDMenu.prototype.toggleMenu = function(submenu) {
- if (submenu.className == "collapsed")
- this.expandMenu(submenu);
- else
- this.collapseMenu(submenu);
- };
- SDMenu.prototype.expandMenu = function(submenu) {
- var fullHeight = submenu.getElementsByTagName("span")[0].offsetHeight;
- var links = submenu.getElementsByTagName("a");
- for (var i = 0; i < links.length; i++)
- fullHeight += links[i].offsetHeight;
- var moveBy = Math.round(this.speed * links.length);
- var mainInstance = this;
- var intId = setInterval(function() {
- var curHeight = submenu.offsetHeight;
- var newHeight = curHeight + moveBy;
- if (newHeight < fullHeight)
- submenu.style.height = newHeight + "px";
- else {
- clearInterval(intId);
- submenu.style.height = "";
- submenu.className = "";
- mainInstance.memorize();
- }
- }, 30);
- this.collapseOthers(submenu);
- };
- SDMenu.prototype.collapseMenu = function(submenu) {
- var minHeight = submenu.getElementsByTagName("span")[0].offsetHeight;
- var moveBy = Math.round(this.speed * submenu.getElementsByTagName("a").length);
- var mainInstance = this;
- var intId = setInterval(function() {
- var curHeight = submenu.offsetHeight;
- var newHeight = curHeight - moveBy;
- if (newHeight > minHeight)
- submenu.style.height = newHeight + "px";
- else {
- clearInterval(intId);
- submenu.style.height = "";
- submenu.className = "collapsed";
- mainInstance.memorize();
- }
- }, 30);
- };
- SDMenu.prototype.collapseOthers = function(submenu) {
- if (this.oneSmOnly) {
- for (var i = 0; i < this.submenus.length; i++)
- if (this.submenus[i] != submenu && this.submenus[i].className != "collapsed")
- this.collapseMenu(this.submenus[i]);
- }
- };
- SDMenu.prototype.expandAll = function() {
- var oldOneSmOnly = this.oneSmOnly;
- this.oneSmOnly = false;
- for (var i = 0; i < this.submenus.length; i++)
- if (this.submenus[i].className == "collapsed")
- this.expandMenu(this.submenus[i]);
- this.oneSmOnly = oldOneSmOnly;
- };
- SDMenu.prototype.collapseAll = function() {
- for (var i = 0; i < this.submenus.length; i++)
- if (this.submenus[i].className != "collapsed")
- this.collapseMenu(this.submenus[i]);
- };
- SDMenu.prototype.memorize = function() {
- if (this.remember) {
- var states = new Array();
- for (var i = 0; i < this.submenus.length; i++)
- states.push(this.submenus[i].className == "collapsed" ? 0 : 1);
- var d = new Date();
- d.setTime(d.getTime() + (30 * 24 * 60 * 60 * 1000));
- document.cookie = "sdmenu_" + encodeURIComponent(this.menu.id) + "=" + states.join("") + "; expires=" + d.toGMTString() + "; path=/";
- }
- };
- </script>
调用方式
HTML:
- var myMenu = new SDMenu("main_menu"); // 菜单ID
- // 默认参数
- myMenu.speed = 3; // 折叠速度
- myMenu.remember = true; // 是否记录状态
- myMenu.oneSmOnly = false; // 一次只有一个菜单打开
- myMenu.markCurrent = true; // 是否高亮当前菜单
- myMenu.init();
- // 附加方法
- var firstSubmenu = myMenu.submenus[0];
- myMenu.expandMenu(firstSubmenu); // 打开一个菜单
- myMenu.collapseMenu(firstSubmenu); // 关闭一个菜单
- myMenu.toggleMenu(firstSubmenu); // 当菜单关闭时打开,当菜单打开时关闭
- myMenu.expandAll(); // 打开所有菜单
- myMenu.collapseAll(); // 关闭所有菜单
滑动式折叠菜单 - Slashdot's Menu的更多相关文章
- CSS:响应式下的折叠菜单(条纹式)
原文:CSS: Responsive Navigation Menu 译文:CSS:响应式导航菜单 译者:dwqs 写在之前,关于如何制作响应式的下拉菜单:响应式下的下拉菜单 之前,我写了一篇关于怎么 ...
- jquery 展开折叠菜单
jquery 展开折叠菜单 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <ht ...
- 顶 兼容各种浏览器js折叠菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JS三级折叠菜单特效 自动收缩其它级
真的很不错!很实用,在IE6.IE7.IE8.FF.chrome等浏览器都正常运行,去掉CSS中 #menu ul中 {height:100px; overflow:auto;} 即可高度自适应 &l ...
- JS+CSS打造三级折叠菜单,自动收缩其它级 js
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...
- slideToggle+slideup实现手机端折叠菜单效果
折叠菜单的效果,网上有很多的插件,比如bootstrap的 Collapse ,很好用也很简单,但是如果你使用的不是bootstrap框架,就会造成很多不必要的麻烦,比如默认样式被修改,代码冗余等等, ...
- 原生Js_实现简单的下拉折叠菜单(添加弹出动画效果)
用javascript实现简单的下拉折叠菜单效果 实现步骤 (a)获得各操作的dom对象: (b)在所有菜单按钮对象上添加单击事件: (c)设置所有菜单按钮样式为空,并将当前按钮的样式设置为“acti ...
- CSS+JS相应式导航菜单
响应式导航菜单 响应式导航菜单就是当网页在其他不同视口的样式,不同的设备需要不同的样式 需要掌握的知识 - 掌握媒体查询,如果你不是很懂那就看我写的CSS响应式布局 掌握CSS重的display:no ...
- 响应式导航菜单(css+js)
1.响应式导航菜单 先来看下效果图把: 当视口大于640px的时候,导航条会显示在外,当视口小于768px的时候,导航菜单需要隐藏起来!代码如下: <!doctype html> < ...
随机推荐
- 【HDU2255】奔小康赚大钱-KM算法
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem Description ...
- Android混淆打包
一.理论知识 ProGuard是一款免费的Java类文件压缩器.优化器和混淆器.它能发现并删除无用类.字段(field).方法和属性值(attribute).它也能优化字节码并删除无用的指令.最后 ...
- 构建ceph deb 安装包
前言:本文基于ubuntu 14.04.5 LTS 和ceph v0.94.3 之上做的实验 一.编译ceph包1.1.克隆ceph代码,切换分支 git clone --recursive http ...
- Spring MVC控制器
Spring MVC中控制器用于解析用户请求并且转换为模型以提供访问应用程序的行为,通常用注解方式实现. org.springframework.stereotype.Controller注解用于声明 ...
- Extjs MVC学习随笔01
Extjs Mvc模式下的整个MVC框架体系即下图: 包含了Controller(实现方法层),Store(数据来源管理层),View(页面布局层).之所以用MVC我想是因为减轻针对某一页面的单一的J ...
- nginx基本配置和参数说明
#运行用户user nobody;#启动进程,通常设置成和cpu的数量相等worker_processes 1; #全局错误日志及PID文件#error_log logs/error.log;#err ...
- vs visual studio 让外网访问设置
vs2015 提供外网访问我是这么解决的 有时我们经常会用到连接外网的方式来调试自己写的莫名bug.而我们通常有两种解决方式 一.捕捉错误日志进行代码分析. 二.则是将我们的源码项目提供外网访问进行直 ...
- webform分页
前端界面: 当前第[<asp:Label ID="Label_nowpage" runat="server" Text="Label" ...
- 一次java性能调优总结
我们的系统中新开发了一个数据抽取的功能,东西做完后,一看执行时间那叫一个恼火.参考同类系统同样功能的执行时间,目标:将本地数据处理时间压缩到5秒以内. 第一步: 要想知道哪个地方需要优化,仅凭感觉 ...
- linux系统下静态IP的设置
首先说明:下面用的系统为:kali 4.6.0版本的哦:不同的系统是不一样的:反正吧,在ubuntu上的好多方法在kali上就不管用,并且吧,不同的ubuntu的版本也不一样的: 第一步:设置网络的I ...