使用javascript oop开发滑动(slide) 菜单控件

这里使用原生的javascript,用面向对象的方式创建一个容易维护使用方便的滑动菜单,调用方式如下:

var $sliding = document.getElementById("silding");
var s1 = new Sliding();
s1.commands 
= $sliding.getElementsByTagName("dt");
s1.panels 
= $sliding.getElementsByTagName("dd"); ;
s1.init(
"mouseover""active");

演示代码分为slide.js和slide.html两个文件

 slide.htm:

ExpandedBlockStart.gif代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>javascript slide控件演示</title>
<style type="text/css">
    
/*reset*/
    dl,ul,li,dt,dd
{ margin:0; padding:0; list-style:none; }
    
/*silding*/
    .silding
{ width:200px; border:1px solid #ccc; line-height:25px; overflow:hidden;}
    .silding dt
{border-bottom:1px solid #ccc; background-color:#bebebe; cursor:pointer}
    .silding dd
{ display:none; background:#efefef; overflow:hidden; font-size:12px; }
    .silding .active
{ font-weight:bold;}
</style>
<script type="text/javascript" src="slide.js"></script>
</head>

<body>
<div id="silding" class="silding">
    
<dl>
        
<dt class="active">第一个一级菜单</dt>
           
<dd style="display:block;">
            
<ul>
                
<li><href="#">第一个二级菜单</a></li>
                
<li>第一个二级菜单</li>
                
<li>第一个二级菜单</li>
            
</ul>
        
</dd>
   
</dl>
    
<dl>
        
<dt>第二个一级菜单</dt>
           
<dd>
            
<ul>
                
<li>第二个二级菜单</li>
                
<li>第二个二级菜单</li>
                
<li>第二个二级菜单</li>
            
</ul>
        
</dd>
   
</dl>
    
<dl>
        
<dt>第三个一级菜单</dt>
           
<dd>
            
<ul>
                
<li>第三个二级菜单</li>
                
<li>第三个二级菜单</li>
                
<li>第三个二级菜单</li>
            
</ul>
        
</dd>
   
</dl>
</div>
<script type="text/javascript">
    
var $sliding = document.getElementById("silding");
    
var s1 = new Sliding();
    s1.commands 
= $sliding.getElementsByTagName("dt");
    s1.panels 
= $sliding.getElementsByTagName("dd"); ;
    s1.init(
"mouseover""active");
</script>
</body>
</html>

slide.js:

ExpandedBlockStart.gif代码

    
function Slider(i, panelHeight) { //dto
        this.index = i;
        
this.panelHeight = panelHeight;
    }
    
 
//class  Sliding {
    function Sliding(activeIndex) {
        
this.commands = [];
        
this.panels = [];
        
this.activeIndex = activeIndex || 0;
        
this.sliderCache = {};
    }
    Sliding.prototype 
= {
        
//绑定事件
        init: function(eventName, activeCssClass) {
            
var _this = this;
            
var cmds = _this.commands;
            _this.activeClass 
= activeCssClass;
            
for (var i = 0, n = cmds.length; i < n; i++) {
                cmds[i][
"on" + eventName] = function(e) {
                    _this.handel(
this, e);
                }
                cmds[i].index 
= i;
                
if (i == _this.activeIndex) {
                    _this.sliderCache 
= new Slider(i, _this.panels[i].offsetHeight);
                }
            }


        },
        
//事件处理函数
        handel: function(elem, args) {
            
var _this = this;
            
var index = elem.index;
            
var cacheIndex = _this.sliderCache.index;
            
var cacheElem =  _this.commands[cacheIndex];
            
if (index == cacheIndex) return;
            
var showPanel = _this.panels[index];
            
var hidePanel = _this.panels[cacheIndex];
            
var h = parseInt(_this.sliderCache.panelHeight);
            showPanel.style.height 
= "0px";
            showPanel.style.display 
= "block";
            _this.tween(hidePanel, showPanel, h);
            elem.className 
= _this.activeClass;
            cacheElem.className 
= cacheElem.className.replace(eval("/ ?"+_this.activeClass+" ?/"),"");
            _this.sliderCache 
= new Slider(index, h);

        },
        
//动画算法
        tween: function(obj0, obj1, h) {
            _this 
= arguments.callee;
            
var step = 20;
            
if ("\v" == "v") {
                step 
= 30;
            }
            
if (h > 0) {
                
var h0 = obj0.offsetHeight;
                
var h1 = obj1.offsetHeight;
                
if (h < step) {
                    obj0.style.display 
= "none";
                    obj0.style.height 
= (h1 + h) + "px";
                    obj1.style.height 
= (h1 + h) + "px";

                } 
else {
                    h 
= h - step;
                    obj0.style.height 
= (h0 - step) + "px";
                    obj1.style.height 
= (h1 + step) + "px";
                    setTimeout(
function() {
                        _this(obj0, obj1, h)
                    },
                    
50)
                }
            }
        }
    }
//}    

 上面就所有代码了这里因为是演示所以让HTML CSS尽量的简化,另外使用jquery的 fn.slideUp fn.slideDown 实现起来会更容易不过我作为一个专业的开发者多了解些原生的JS对技术的提高还是很有帮助。

转载于:https://www.cnblogs.com/rentj1/archive/2010/08/20/1805024.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/299100.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

这段代码什么意思啊?

这段代码什么意思啊? Delphi / Windows SDK/APIhttp://www.delphi2007.net/DelphiDB/html/delphi_20061217214802252.htmlprocedure TForm3.RadioButton3Click(Sender: TObject); begin ADOTable1.refresh; with ADOTable1 do try disablecontrols; filte…

他毕业于北师大,编写了我国首套数学教材,陈景润华罗庚都崇拜他

全世界只有3.14 % 的人关注了爆炸吧知识要说起我国著名的数学家&#xff0c;很多人会想到陈景润、华罗庚等人&#xff0c;这些大数学家为我国数学研究做出了卓越贡献&#xff0c;也深深影响了很多人。那么&#xff0c;像陈景润、华罗庚这些大数学家&#xff0c;他们学习数学有受…

用多媒体库 Bass.dll 播放 mp3 [8] - 实时显示左右声道的峰值

为什么80%的码农都做不了架构师&#xff1f;>>> 本例效果图: 代码文件: unit Unit1;interfaceusesWindows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,Dialogs, StdCtrls, ExtCtrls, ComCtrls;typeTForm1 class(TForm)OpenDialog1: TOpe…

最近看了两本低代码的书

月初写了一篇《你真的了解低代码平台吗&#xff1f;》&#xff0c;介绍了下我对低代码产品的一些认识&#xff0c;随后有朋友送了我两本华章出版的关于低代码的书&#xff1a;明道云的《零代码实战》和微软的《实战低代码》&#xff0c;目前市面上也就这两本关于低代码的书。因…

如何逼疯一名数学系学生?

全世界只有3.14 % 的人关注了爆炸吧知识今天在知乎竟看到这样一个问题但看在关注人数如此之多超模君就放下成见稍微透露一下我们的“底线”到底要怎样做才能激怒数学系学生数学沾边法顾名思义只要和数学沾边就可以开怼在菜市场算菜钱时在提问后的0.5秒迅速补上致命一刀经过彩票…

java 图片压缩 base64_图片改变像素,宽高,Base64编码处理

1.改变图片像素private void setAlpha(String os) {/*** 增加测试项* 读取图片&#xff0c;绘制成半透明,修改像素*/try {ImageIcon imageIcon new ImageIcon(os);BufferedImage bufferedImage new BufferedImage(imageIcon.getIconWidth(),imageIcon.getIconHeight(), Buffe…

WinAPI: 钩子回调函数之 MouseProc

为什么80%的码农都做不了架构师&#xff1f;>>> MouseProc(nCode: Integer; {}wParam: WPARAM; {}lParam: LPARAM {} ): LRESULT; {}//待续...转载于:https://my.oschina.net/hermer/blog/320962

shell对于字符串的操作

shell对于字符串的操作:以下为代码内容&#xff1a;得到长度 代码:%x"abcd" # 方法一 %expr length $x 4 # 方法二 %echo ${#x} 4 # 方法三 %expr "$x" : ".*" 4 # expr 的帮助 # STRING : REGEXP anchored pattern match of REGEXP in STRING…

方法参数修饰符in,out,ref

in&#xff0c;out&#xff0c;ref都可能作为方法参数据修饰符&#xff0c;从字面意思可就可以理解这三个关键字的含义&#xff0c;那用法是什么样子的呢&#xff0c;通过demo来看一下。定义一个引用类型Orderpublic class Order {public string OrderNo { get; set; }public o…

hdoj 1272

题目链接http://acm.hdu.edu.cn/showproblem.php?pid1272 并查集 1 #include <iostream>2 #include <algorithm>3 4 usingnamespacestd;5 6 intf[100001];7 booldis[100001];8 9 intFind(intx)10 {11 while( x !f[x] ){12 x f[x];13 }14 15 returnx;16 }17 18 int…

配置Tomcat的日志系统

成功配置tomcat的log4j日志系统&#xff0c;格式&#xff1a;HTML&#xff0b;每天以yyyy-mm-dd.log命名的日志文件一、引言&#xff1a;实习单位让用log4j配置webapp的日志系统&#xff0c;要求产生的日志文件是html格式&#xff0c;而且是每天以yyyy-mm-dd日期格式命名的日志…

python训练词库_在Python中训练NGramModel

首先,正如您对问题的评论中所指出的,如果培训/运行速度对您来说是一个问题,KenLM可能是更好的选择.此时nltk.model主要用于教育/原型设计,但它并不快.如果您仍然决定坚持使用NLTK,请继续阅读.我碰巧是模型分支中新的NgramModel代码的作者,我会尝试清楚地说明你可以测试代码并让…

内推!字节、阿里、网易火热招聘中,内推优筛简历,快人一步拿offer,真香!(送内推码)...

全世界只有3.14 % 的人关注了爆炸吧知识“金三银四”可谓招聘的黄金期。一方面&#xff0c;校园春招正如火如荼的进行中&#xff0c;另一方面&#xff0c;各大企业也纷纷启动了暑假实习招聘。对于2020届的同学来说&#xff0c;务必要利用好“应届生”这个身份&#xff0c;把握住…

如何将10进制转成16进制,又如何将16进制数转成10进制,C#和VB代码?

方法1&#xff1a; int d10; d.ToString("x") //或把x改为&#xff38;&#xff0c;&#xff0c;&#xff0c;就变成了&#xff11;&#xff16;位的字符串了&#xff0e; int xConvert.ToInt32(d.ToString("x"),16);&#xff0f;&a…

C#怎么测试静态方法?我给出了2种方案

问题假设有一个方法需要判断当前小时范围&#xff0c;代码如下&#xff1a;public class Class1 {public bool SomeMethod(){var hour DateTime.Now.Hour;if (hour > 9 && hour < 12){return true;}return false;} }但是&#xff0c;在做单元测试时&#xff0c;…

关于Tomcat5.5中EL表达式无效的解决办法

问题&#xff1a; 在Tomcat5.5中&#xff0c;JSP页中使用EL表达式输出信息&#xff0c;例如&#xff1a; <% page language”java” import”java.util.*” pageEncoding”UTF-8″%><html><head>EL表达式</head><body>${header["User-Agent…

c语言全局变量和局部变量问题汇总

1、局部变量是否能和全局变量重名&#xff1f; 答&#xff1a;能&#xff0c;局部会屏蔽全局。要用全局变量&#xff0c;须要使用"::" 局部变量能够与全局变量同名&#xff0c;在函数内引用这个变量时&#xff0c;会用到同名的局部变量&#xff0c;而不会用到全局变…

本科4篇顶会论文如何做到?清华特奖高天宇干货分享:我是这样写论文、做实验、与导师相处...

全世界只有3.14 % 的人关注了爆炸吧知识本科生&#xff0c;距离“科研”有多远&#xff1f;有人还处在“小朋友你是否有很多问号”的状态&#xff0c;但也有人本科就连发顶会文章&#xff0c;光环闪瞎众人。其中可有什么秘诀&#xff1f;清华本科特奖获得者、清华计算机大四学生…

java final 修改_“无法改变的设计”——浅谈Java中的final关键字

在Java中&#xff0c;final关键字可以用来修饰类、变量(包括成员变量和局部变量)、方法&#xff0c;下面从这三个方面分别说明。final方法当一个方法被final修饰时&#xff0c;表明这个方法不能被子类重写。下面程序试图重写final方法&#xff0c;将会引发编译错误。public cla…

数据库日志的说明

清日志 如 dump transaction 数据库名 with no_log --清除日志backup log 数据库名 with no_log --截断事务日志dbcc shrinkdatabase(数据库名,10) --收缩的数据库&#xff0c;空出10%的空间来 先执行上面两句&#xff0c;这两句比较快…