Mootools 1.2教程(20)——选项卡效果(Tabs)

作者:Fdream 来源:Fdream博客 时间:2008-12-26 18:19:00 

原文地址:30 Days of Mootools 1.2 Tutorials - Day 20 - A Few Mootools Tabs

项目——创建选项卡效果的几种方式

阅读上一讲:Mootools 1.2教程(19)——Tooltips

今天将不只是受限于这个库和一些基本的编程知识,我们来做一个简单的小项目。通过使用我们目前为止已经学过的一些知识,有几种方式来创建当鼠标移上去或者点击时显示相应内容的tab。

简单的“额外信息”标签(TAB)

鼠标移上去显示内容的TAB

在这第一个项目中,我们要创建一个简单的菜单,当鼠标移动到这些菜单上时显示相应的内容。首先,我们来完成HTML代码——我们就用包含四个列表项的ul好了,然后再创建四个div(每一个div对应一个列表项):

参考代码: 

// 这里是我们的菜单 
<ul id="tabs"> 
    <li id="one">One</li> 
    <li id="two">Two</li> 
    <li id="three">Three</li> 
    <li id="four">Four</li> 
</ul> 

// 这里是我们的内容div 
<div id="contentone" class="hidden">content for one</div> 
<div id="contenttwo" class="hidden">content for two</div> 
<div id="contentthree" class="hidden">content for three</div> 


现在,我们不需要关心怎么把它们做得漂亮。在CSS中,我们要做的全部事情就是把内容区块隐藏起来:

参考代码: 

.hidden { 
    display: none; 



好了,现在开始写MooTools代码。如果我们需要当用户把鼠标移上去的时候显示内容,当鼠标离开的时候隐藏内容,我们需要完成这样两个函数:

参考代码: 

var showFunction = function() { 
    this.setStyle('display', 'block'); 


var hideFunction = function() { 
    this.setStyle('display', 'none'); 


还有一些事件:

参考代码: 

window.addEvent('domready', function() { 
    // 这里我们可以把容器元素赋值给一个变量 
    var elOne = $('contentone'); 

    $('one').addEvents({ 
        // 当鼠标进入的时候,我们调用showFunction 
        // 并绑定这个元素elOne 
        // 因此我们需要把它作为函数参数 
        'mouseenter': showFunction.bind(elOne), 
        'mouseleave': hideFunction.bind(elOne) 
    }); 


现在,我们只需要为每个tab重复这个模式,并指定对应的内容区块就可以了。下面是完整的代码:

参考代码: 

// 这里是用来改变样式的函数 
var showFunction = function() { 
    this.setStyle('display', 'block'); 


var hideFunction = function() { 
    this.setStyle('display', 'none'); 


window.addEvent('domready', function() { 
    // 在这里我们把我们的内容块赋值给不同变量 
    var elOne = $('contentone'); 
    var elTwo = $('contenttwo'); 
    var elThree = $('contentthree'); 
    var elFour = $('contentfour'); 

    // 给tab绑定事件 
    $('one').addEvents({ 
        // 设置事件类型 
        // 并给事件控制函数绑定相应的变量 
        'mouseenter': showFunction.bind(elOne), 
        'mouseleave': hideFunction.bind(elOne) 
    }); 

    $('two').addEvents({ 
        'mouseenter': showFunction.bind(elTwo), 
        'mouseleave': hideFunction.bind(elTwo) 
    }); 

    $('three').addEvents({ 
        'mouseenter': showFunction.bind(elThree), 
        'mouseleave': hideFunction.bind(elThree) 
    }); 

    $('four').addEvents({ 
        'mouseenter': showFunction.bind(elFour), 
        'mouseleave': hideFunction.bind(elFour) 
    }); 



正如你所看到的,这一切看起来都非常的熟悉,完成这些并不需要任何我们目前为止没有学过的东西。

借鉴上面的想法,我们可以很轻松地调整它为点击时显示内容。我们就使用上面的HTML,然后修改一下MooTools代码,以完成点击事件。

首先,我们需要调整一下我们的函数。由于我们不能在鼠标离开时把内容隐藏起来,因此,我们需要换一种方式来切换这些div。可能最容易的选择是在点击时首先把它们全部隐藏起来,然后只把this(通过click事件传递进来的对象)所指的当前的内容显示出来。

参考代码: 

var showFunction = function() { 
    $$('.hiddenB').setStyle('display', 'none');  
    this.setStyle('display', 'block'); 
}



现在,当我们通过把元素绑定到一个函数上来传递这个变量时,它将隐藏其他的区块,并显示当前的区块。

接下来,我们还需要调整一下我们的事件。首先,我们只需要一个事件了,因此我们使用.addEvent();方法,然后还需要改变事件的类型为“click”。

参考代码: 

window.addEvent('domready', function() { 
    var elOneB = $('contentoneB'); 
    var elTwoB = $('contenttwoB'); 
    var elThreeB = $('contentthreeB'); 
    var elFourB = $('contentfourB'); 

    $('oneB').addEvent('click', showFunction.bind(elOneB)); 
    $('twoB').addEvent('click', showFunction.bind(elTwoB)); 
    $('threeB').addEvent('click', showFunction.bind(elThreeB)); 
    $('fourB').addEvent('click', showFunction.bind(elFourB)); 

标签:Mootools,Tabs,教程,选项卡,javascript
0
投稿

猜你喜欢

  • WEB2.0网页制作标准教程(4)如何调用css样式表

    2007-11-13 13:26:00
  • select 终极美化

    2007-10-16 17:57:00
  • 需要掌握的八个CSS布局技巧

    2008-05-17 11:45:00
  • 文档标准的真实谎言

    2008-06-02 10:46:00
  • MySQL数据库搜索中的大小写敏感性

    2008-11-24 12:44:00
  • HTML5 WebSockets基础使用教程

    2010-09-21 12:48:00
  • 从客户端提升SQL Server数据库性能

    2009-03-06 14:27:00
  • ASP中 ADODB.Stream 语法速查

    2008-01-27 15:23:00
  • 运行SQL Server的计算机间移动数据库

    2009-01-20 13:07:00
  • [图]关于网站开发中缓存 cache应用

    2008-08-19 18:14:00
  • DW MX 的快键一览表

    2009-07-21 12:47:00
  • W3C Group的JavaScript1.8新特性介绍

    2009-07-24 12:31:00
  • 去掉CSS赘余代码,CSS可以更简洁

    2008-11-05 13:07:00
  • css基础教程之序曲

    2008-07-23 12:40:00
  • Javascript Closures (2)

    2009-03-18 12:22:00
  • 图片放大镜,多图片放大(已更新)[可调整倍数、区域大小、展示区域位置]

    2011-06-16 20:43:07
  • 视觉注意力—解剖设计的根源

    2010-01-22 15:12:00
  • asp如何自动更新导航栏?

    2010-07-07 12:10:00
  • 页面重构应注意的repaint和reflow

    2011-03-31 17:11:00
  • 设计的商业价值

    2009-08-13 14:43:00
  • asp之家 网络编程 m.aspxhome.com