使用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,一经查实,立即删除!

相关文章

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

全世界只有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秒迅速补上致命一刀经过彩票…

WinAPI: 钩子回调函数之 MouseProc

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

内推!字节、阿里、网易火热招聘中,内推优筛简历,快人一步拿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…

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

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

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

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

一致性 hash 算法( consistent hashing )

consistent hashing 算法早在 1997 年就在论文 Consistent hashing and random trees 中被提出&#xff0c;目前在cache 系统中应用越来越广泛&#xff1b; 1 基本场景 比如你有 N 个 cache 服务器&#xff08;后面简称 cache &#xff09;&#xff0c;那么如何将一个对象 obje…

复工之后,如何让自己的时间更值钱

全世界只有3.14 % 的人关注了爆炸吧知识时间最不偏私给任何人都是二十四小时时间也最偏私给任何人都不是二十四小时而如何让自己的时间更值钱以下公众号或许能给你一些启示赶快扫码关注吧&#xff01;RSS精选ID&#xff1a;KindleNewsRSS精选是一个专注于时间管理iOS相关及Kind…

selenium autoit java_Java+Selenium——AutoIt工具处理文件上传

关于文件上传&#xff0c;这边介绍一个第三方工具&#xff0c;叫AutoIt&#xff0c;简单来说&#xff0c;这个是一个能支持桌面GUI自动化的工具&#xff0c;它支持脚本语言编写。这里&#xff0c;我们用AutoIt来做文件上传的演示。在Selenium脚本中如果需要AutoIt来协助这个文件…

Blazor+Dapr+K8s微服务之开发环境调试

1 安装Dapr开发调试环境1.1 Dapr 完整安装模式不支持开发调试在上一篇随笔《BlazorDaprK8s微服务之服务调用》中&#xff0c;我们通过为每个微服务运行dapr run ….dotnet run命令&#xff0c;以自宿主的方式在本地开发环境成功运行了服务调用的例子。但是&#xff0c;这种运行…

这10个人,总是牛逼的无话可说

全世界只有3.14 % 的人关注了爆炸吧知识终于迎来知识君最喜欢的工作日了。热爱工作的知识君还是在认真地看书&#xff0c;码字。哈哈哈&#xff0c;有模友知道看得是什么书然而在拍完照片后&#xff0c;还是得想想今晚该写些啥东西。狄拉克 保罗狄拉克(Paul Adrien Maurice …

WebSocket服务器(物联网下行通知神器)

HttpServer是一个轻量级Web服务器&#xff0c;用于在嵌入式设备以及客户端环境中提供简单Web服务&#xff0c;同时也支持标准WebSocket服务。本文例程基于vs2022&#xff0c;基础例程可参考&#xff1a;https://www.yuque.com/smartstone/nx/httpserverWebSocket服务端WebSocke…

继续送假期干货——响应式图片工具smartImg

中午看《众妙之门》看到一个响应式图片处理工具&#xff08;点此查看&#xff09;的介绍&#xff0c;然后就心血来潮想着不妨自己写一个基于JQ的吧&#xff0c;于是就又有了这么一个干货给大家。 smartImg 的全部文件可以从我的Github上下载&#xff0c;其实它非常小巧&#xf…

一顿家庭火锅让本不富裕的家庭雪上加霜......

1 从此再也没有人相信你曾是个双眼皮▼2 在家吃火锅让一个本不富裕的家庭雪上加霜▼3 大型翻车现场▼4 各位大爷大伯&#xff0c;我先干了招待不周&#xff0c;还望海涵▼5 老外为了防止用手摸脸导致传染发明出来的新方法 ......但这东西难道不是宠物那啥用的吗&#xff1…

ASP.NET Core 修改开源协议为MIT,.NET全平台 MIT协议开源了

2021年7月23日&#xff0c;.NET开发团队完成了所有的.NET平台的相关框架的MIT协议更改&#xff0c;我们可以通过 https://github.com/dotnet/aspnetcore/issues/18873 看到详细的修改提交&#xff0c;这个协议修改里面主要有2点&#xff0c;具体可以看 https://github.com/dotn…

InstallSield更新包快速入门文档----感谢原作者ㄣ齊¨彡仯乄的无私提供

本文经原作者ㄣ齊彡仯乄特许授权于海洋女神发布&#xff0c;转载请务必注明出处与链接&#xff1b;原作者ㄣ齊彡仯乄和海洋女神保留对该文的一切法律许可下的权益&#xff1b;需要发布在盈利性报刊、网站等请与原作者ㄣ齊彡仯乄或海洋女神联系. 简述 本文主要描述安装程序更新包…

太赞了:中文版开源!这或许是最经典的计算机编程教材

全世界只有3.14 % 的人关注了爆炸吧知识转自 AI 科技大本营《Think Python》是很多计算机初学者的不二入门教材&#xff0c;受到广泛好评。该书原作者是美国 Olin 工程学院的教授 Allen B. Downey&#xff0c;目前该书的原版和中文版本都已免费开源。Allen 称&#xff0c;《Thi…