• Mootools中使用extend和implement给你的函数扩展功能或方法


      当然了,所谓的给函数扩展功能或方法指的是不修改原函数的前提下.

    很多人都知道Mootools面向对象的机制不错,不过多数人都把面向对象理解错了,认为面向对象就是类,其实不然,面向对象的范围是非常广的.

    那么我的这篇文章实际上就是面向对象的一种应用,只不过这个对象是一个function,而并非class.

    //给指定Function扩展新的方法或属性
    var Fun=function(){
      alert('a')
    };
    Fun.extend({
      aa:function(){
        alert('b');
      }
    });
    Fun();
    Fun.aa();

    在上边这段代码中函数Fun唯一的用途就是用来输出a这个字符,此时我们把这个函数理解成是一个对象,那如果我们要给这个函数增加一个新的方法,让他除了能输出a之外还能输出b

    因此我就是用了extend对Fun这个对象进行了一次方法扩展,注意扩展之后的方法调用的时候会略有不同.

    下边的例子同时演示了如何扩展属性和方法.

    var arr=[];
    var Fun=function(){
    arr=[1,2];
    };
    Fun.extend({
    len:function(){//给Fun扩展属性
    return arr.length;
    },
    add:function(val){//给Fun扩展方法
    arr.push(val);
    }
    });

    var a=Fun.len(arr);
    alert(a+'|'+arr);//此时输出:0|

    Fun();//调用此函数给arr赋值

    var a=Fun.len();
    alert(a+'|'+arr);//此时输出:2|1,2

    Fun.add('新的');

    var a=Fun.len();
    alert(a+'|'+arr);//此时输出:3|1,2,新的

    Fun.add(['a','b','c']);

    var a=Fun.len();
    alert(a+'|'+arr);//此时输出:4|1,2,新的,a,b,c

    len是我扩展的属性,用来取得arr的length数,而add则是一个方法,用来给arr这个array添加新的值

    implement是用来给所有的函数扩展方法的,其实很好理解,我们已经知道在Mootools中有pass,bind,delay等等的方法,这些方法都是Mootools为我们预定义的

    但是如果你在实际开发过程中发现他为我们预定义的方法不能满足我们的需求,此时怎么办呢,很简单,只要自己扩展就好了,看下边:

    //扩展新的Function
    var a=function(){};
    var b=function(){};
    Function.implement({
    alert:function(msg){//直接alert输出内容
    alert(msg);
    },
    output:function(msg){//firebug的控制台会输出内容,IE会报错
    console.log(msg);
    }
    });
    a.alert('1');
    a.output('2');
    b.output('3');


    看过这篇文章之后您是否对Mootools的面向对象有了一个新的认识呢?

  • 相关阅读:
    Android 去除最上面应用名称及图标
    Android 仿QQ消息界面
    多线程断点续传及下载
    android 断点下载---XUtils
    Android判断网路是否畅通加权限
    Android_按两次返回键退出程序和长按返回键退出程序
    Android JPush(极光推送)的使用教程
    使用VS2013自带的PreEmptive Dotfuscator and Analytis来混淆C#代码
    Entity Framework 6连接Oracle、Postgresql、SQLite、LocalDB数据库字符串详解
    Fluent Nhibernate 数据库配置
  • 原文地址:https://www.cnblogs.com/see7di/p/2247742.html
Copyright © 2020-2023  润新知