用不同方法完成同样一个任务:启动和停止动画。

1.过程式的程序设计:

function startAnimation(){
...
}

function stopAnimation(){
...
}

缺点:无法创建可以保存状态,并且进行一些内部操作的方法,所以2.创建对象的方法如下:

var Anim = function(){
...
}

Anim.prototype.start = function(){
...
}
Anim.prototype.stop = function(){
...
}

var myAnim = new Anim();

myAnim.start();
myAnim.stop();

3.当然也可以把上面类的定义封装在一条声明当中,如下:

var Anim = function(){
...
}

Anim.prototype = {
    start:function(){},
    stop:function(){}
}

上面的是大多数屌丝程序员常用的方法,4.下面是逼格更高的写法:

Function.prototype.method = function(name,fn){
    this.prototype[name] = fn;
}

var Anim = function(){
...
}

Anim.method('start',function(){
...
});

Anim.method('stop',function(){
...
});

说明:Function.prototype.method用于为类添加新方法,2个参数(方法名,新的方法)

5.当然也可以继续更改Function.prototype.method,使其可以被链调用,只要让他返回this即可

Function.prototype.method = function(name.fn){
    this.prototype[name] = fn;
    return this;
};

var Anim = function(){

};
Anim.
    method('start',function(){
    ...
    }).
    method('stop',function(){
    ...
    });

以上5种方法,均可以完成同一项任务。

==========

函数的特性:

1.可以存储在变量当中

2.可以作为参数传给其他函数

3.可以作为返回值从其他函数传出

4.可以在运行时进行构造

匿名函数实例:

(function(){
    var foo = 10;
    var bar = 2;
    alert(foo*bar);
})();
//被定义后立即执行,函数最后一对括号立即对函数进行调用,括号中没有参数。
(function(foo,bar){
    alert(foo*bar);
})(10,2);

//变量做为参数传递进去

var baz = (function(){
    return foo*bar;//返回值赋给变量baz
})(10,2);

函数有一个用途就是创建闭包。

1.Javascript有函数级作用域,定义在函数内部的变量不能再外部被调用。

2.函数运行在定义它的作用域中,而不是在调用它的作用域中。

var baz;
(function(){
    var foo = 10;
    var bar = 2;
    baz = function(){
        return foo*bar;
    }
})();

baz();

《Javascript设计模式》笔记一js的表现力的更多相关文章

  1. Javascript设计模式笔记

    Javascript是越来越厉害了,一统前后端开发.于是最近把设计模式又看了一遍,顺便做了个笔记,以方便自己和他人共同学习. 笔记连载详见:http://www.meteorcn.net/wordpr ...

  2. Javascript 设计模式笔记

    设计模式太多了 还有些模式概念非常接近(比如观察者 中介者 和 事件发布/订阅模式) 构造器模式 var newObject = {} var newObject = new XXX(); 模块模式 ...

  3. javascript学习笔记(四) Number 数字类型

    数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数  toExponential() 方法 用科学 ...

  4. javaScript设计模式之面向对象编程(object-oriented programming,OOP)(二)

    接上一篇 面向对象编程的理解? 答:面向对象编程,就是将你的需求抽象成一个对象,然后针对这个对象分析其特征(属性)与动作(方法).这个对象我们称之为类.面向对象编程思想其中一个特点就是封装,就是把你需 ...

  5. JavaScript基础笔记集合(转)

    JavaScript基础笔记集合   JavaScript基础笔记集合   js简介 js是脚本语言.浏览器是逐行的读取代码,而传统编程会在执行前进行编译   js存放的位置 html脚本必须放在&l ...

  6. 再起航,我的学习笔记之JavaScript设计模式01

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 在通 ...

  7. 再起航,我的学习笔记之JavaScript设计模式03

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 上一 ...

  8. 再起航,我的学习笔记之JavaScript设计模式05(简单工程模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

  9. 再起航,我的学习笔记之JavaScript设计模式05(简单工厂模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

随机推荐

  1. amgular $q用法

    amgular $q用法   在用JQuery的时候就知道 promise 是 Js异步编程模式的一种模式,但是不是很明白他跟JQuery的deferred对象有什么区别.随着公司项目的进行,要跟后台 ...

  2. linux常用的命令

    Linux简介及Ubuntu安装 Linux,免费开源,多用户多任务系统.基于Linux有多个版本的衍生.RedHat.Ubuntu.Debian 安装VMware或VirtualBox虚拟机.具体安 ...

  3. android 弹出对话框之四周变暗处理方式

    设置对话框的dim值即可 WindowManager.LayoutParams lp=popDlg.getWindow().getAttributes(); lp.dimAmount = 0.0f; ...

  4. sql 保留两位小数+四舍五入

    1. ROUND(该函数,只是负责四舍五入到两位小数,但是不负责截断 只留两位小数,例如下例:) 关于ROUND函数,我们平常理解为4舍5入,如: print ROUND(13.145, 2); 结果 ...

  5. Android动态方式破解apk终极篇(加固apk破解方式)

    一.前言 今天总算迎来了破解系列的最后一篇文章了,之前的两篇文章分别为: 第一篇:如何使用Eclipse动态调试smali源码 第二篇:如何使用IDA动态调试SO文件 现在要说的就是最后一篇了,如何应 ...

  6. python 学习笔记 redis操作

    Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...

  7. CSS样式表(三)

    前端人员在学习开发过程中常用的CSS样式总结: [margin] margin 检索或设置对象四边的外延边距 margin-top 检索或设置对象顶边的外延边距 margin-right 检索或设置对 ...

  8. 渗透杂记-2013-07-13 Windows XP SP2-SP3 / Windows Vista SP0 / IE 7

    Welcome to the Metasploit Web Console! | | _) | __ `__ \ _ \ __| _` | __| __ \ | _ \ | __| | | | __/ ...

  9. 1007. Maximum Subsequence Sum (25)

    Given a sequence of K integers { N1, N2, ..., NK }. A continuous subsequence is defined to be { Ni, ...

  10. 1005. Spell It Right (20)

    Given a non-negative integer N, your task is to compute the sum of all the digits of N, and output e ...