最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Mootools1.2教程选项卡效果(Tabs)_Mootools

来源:懂视网 责编:小采 时间:2020-11-27 20:44:24
文档

Mootools1.2教程选项卡效果(Tabs)_Mootools

Mootools1.2教程选项卡效果(Tabs)_Mootools:简单的额外信息标签(TAB) 鼠标移上去显示内容的TAB 在这第一个项目中,我们要创建一个简单的菜单,当鼠标移动到这些菜单上时显示相应的内容。首先,我们来完成HTML代码——我们就用包含四个列表项的ul好了,然后再创建四个div(每一个div对应一个列
推荐度:
导读Mootools1.2教程选项卡效果(Tabs)_Mootools:简单的额外信息标签(TAB) 鼠标移上去显示内容的TAB 在这第一个项目中,我们要创建一个简单的菜单,当鼠标移动到这些菜单上时显示相应的内容。首先,我们来完成HTML代码——我们就用包含四个列表项的ul好了,然后再创建四个div(每一个div对应一个列

简单的“额外信息”标签(TAB)
鼠标移上去显示内容的TAB
在这第一个项目中,我们要创建一个简单的菜单,当鼠标移动到这些菜单上时显示相应的内容。首先,我们来完成HTML代码——我们就用包含四个列表项的ul好了,然后再创建四个div(每一个div对应一个列表项):
参考代码:
代码如下:
// 这里是我们的菜单

  • One

  • Two

  • Three

  • Four


  • // 这里是我们的内容div
    content for one
    content for two
    content for three
    content for four

    现在,我们不需要关心怎么把它们做得漂亮。在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)
    });
    });

    正如你所看到的,这一切看起来都非常的熟悉,完成这些并不需要任何我们目前为止没有学过的东西。
    One
    Two
    Three
    Four
    content for one
    content for two
    content for three
    content for four
    点击时显示内容的TAB
    借鉴上面的想法,我们可以很轻松地调整它为点击时显示内容。我们就使用上面的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));
    });

    One
    Two
    Three
    Four
    content for one
    content for two
    content for three
    content for four
    给Tab的内容块加上形变
    通过扩展我们上面的代码,我们可以添加一些形变效果来显示我们隐藏的内容区块。首先,我们可以像以前那样创建一个Fx.Morph效果,不过在这里要设置不同的样式。当然,我们还需要创建我们的形变(Morph)对象:
    参考代码:
    代码如下:
    var showFunction = function() {
    // 在形变之前初始化所有样式
    $$('.hiddenM').setStyles({
    'display': 'none',
    'opacity': 0,
    'background-color': '#fff',
    'font-size': '16px'
    });
    // 在这里开始形变,并指定形变后的样式
    this.start({
    'display': 'block',
    'opacity': 1,
    'background-color': '#d3715c',
    'font-size': '31px'
    });
    }
    window.addEvent('domready', function() {
    var elOneM = $('contentoneM');
    var elTwoM = $('contenttwoM');
    var elThreeM = $('contentthreeM');
    var elFourM = $('contentfourM');
    // 创建一个形变对象
    elOneM = new Fx.Morph(elOneM, {
    link: 'cancel'
    });
    elTwoM = new Fx.Morph(elTwoM, {
    link: 'cancel'
    });
    elThreeM = new Fx.Morph(elThreeM, {
    link: 'cancel'
    });
    elFourM = new Fx.Morph(elFourM, {
    link: 'cancel'
    });
    $('oneM').addEvent('click', showFunction.bind(elOneM));
    $('twoM').addEvent('click', showFunction.bind(elTwoM));
    $('threeM').addEvent('click', showFunction.bind(elThreeM));
    $('fourM').addEvent('click', showFunction.bind(elFourM));
    });

    如果我们使用和上面相同的HTML代码,我们将得到类似这样的效果:
    One
    Two
    Three
    Four
    content for one
    content for two
    content for three
    content for four
    注意:如果你快速地点击上面的示例,你将看的会同时出现多个内容区块。从根本上讲,如果showFunction在上一个形变完成之前调用,它将不会隐藏其他的区块内容。要解决这个问题,我们需要打破这一规则,并充分利用Fx.Elements。
    代码示例
    下面的这个示例和上面的示例差不多,不过当你快速地点击两个tab时,将不会同时出现多个内容div。
    参考代码:
    代码如下:
    // 创建一个隐藏所有元素的函数
    // 你可以把元素作为参数传递进来
    var hideAll = function(fxElementObject){
    fxElementObject.set({
    '0': {
    'display': 'none'
    },
    '1': {
    'display': 'none'
    },
    '2': {
    'display': 'none'
    },
    '3': {
    'display': 'none'
    }
    });
    }
    // 这里我们为每个内容区块创建一个函数
    var showFunctionOne = function() {
    // 首先,调用函数hideAll
    // 然后Fx.element对象的引用“this”作为参数传入
    hideAll(this);
    // 开始相应元素的Fx.element形变动画
    this.start({
    '0': {
    'display': ['none', 'block'],
    'background-color': ['#fff', '#999'],
    'font-size': ['16px', '25px']
    }
    });
    }
    var showFunctionTwo = function() {
    hideAll(this);
    this.start({
    '1': {
    'display': ['none', 'block'],
    'background-color': ['#fff', '#999'],
    'font-size': ['16px', '25px']
    }
    });
    }
    var showFunctionThree = function() {
    hideAll(this);
    this.start({
    '2': {
    'display': ['none', 'block'],
    'background-color': ['#fff', '#999'],
    'font-size': ['16px', '25px']
    }
    });
    }
    var showFunctionFour = function() {
    hideAll(this);
    this.start({
    '3': {
    'display': ['none', 'block'],
    'background-color': ['#fff', '#999'],
    'font-size': ['16px', '25px']
    }
    });
    }
    window.addEvent('domready', function() {
    // 建立一个数组来保存Fx.elements
    var morphElements = $$('.hiddenMel');
    // 创建一个新的Fx.Element对象
    var elementEffects = new Fx.Elements(morphElements, {
    // 设置"link"选项的值为cancel
    link: 'cancel'
    });
    $('oneMel').addEvent('click', showFunctionOne.bind(elementEffects));
    $('twoMel').addEvent('click', showFunctionTwo.bind(elementEffects));
    $('threeMel').addEvent('click', showFunctionThree.bind(elementEffects));
    $('fourMel').addEvent('click', showFunctionFour.bind(elementEffects));
    });

    更多学习
    这篇教程更多地是复习和应用我们在以前的教程中学些的东西。因此,如果你还么准备好,我们建议你全面阅读相应的文档。这比听起来的会更有趣。如果你是刚接触这个库的,但是一直在学习这一系列的教程,你可能会对你了解的程度非常的惊讶。(Fdream注:这个意思就是说,这一系列的教程中,覆盖的内容还不够全面,因此强烈建议大家仔细阅读全部文档。)

    下载最后一个示例的代码

    也包含你开始实践所需要的所有东西。

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    Mootools1.2教程选项卡效果(Tabs)_Mootools

    Mootools1.2教程选项卡效果(Tabs)_Mootools:简单的额外信息标签(TAB) 鼠标移上去显示内容的TAB 在这第一个项目中,我们要创建一个简单的菜单,当鼠标移动到这些菜单上时显示相应的内容。首先,我们来完成HTML代码——我们就用包含四个列表项的ul好了,然后再创建四个div(每一个div对应一个列
    推荐度:
    标签: 括号 (tab) mootools
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top