《Javascript设计模式》笔记一js的表现力
用不同方法完成同样一个任务:启动和停止动画。
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的表现力的更多相关文章
- Javascript设计模式笔记
Javascript是越来越厉害了,一统前后端开发.于是最近把设计模式又看了一遍,顺便做了个笔记,以方便自己和他人共同学习. 笔记连载详见:http://www.meteorcn.net/wordpr ...
- Javascript 设计模式笔记
设计模式太多了 还有些模式概念非常接近(比如观察者 中介者 和 事件发布/订阅模式) 构造器模式 var newObject = {} var newObject = new XXX(); 模块模式 ...
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- javaScript设计模式之面向对象编程(object-oriented programming,OOP)(二)
接上一篇 面向对象编程的理解? 答:面向对象编程,就是将你的需求抽象成一个对象,然后针对这个对象分析其特征(属性)与动作(方法).这个对象我们称之为类.面向对象编程思想其中一个特点就是封装,就是把你需 ...
- JavaScript基础笔记集合(转)
JavaScript基础笔记集合 JavaScript基础笔记集合 js简介 js是脚本语言.浏览器是逐行的读取代码,而传统编程会在执行前进行编译 js存放的位置 html脚本必须放在&l ...
- 再起航,我的学习笔记之JavaScript设计模式01
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 在通 ...
- 再起航,我的学习笔记之JavaScript设计模式03
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 上一 ...
- 再起航,我的学习笔记之JavaScript设计模式05(简单工程模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...
- 再起航,我的学习笔记之JavaScript设计模式05(简单工厂模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...
随机推荐
- Nudnik Photographer -Ural1260动态规划
Time limit: 1.0 second Memory limit: 64 MB If two people were born one after another with one second ...
- 网易测试分享会——“一起打造你想要的QA团队”
昨天(2016.11.30)参加了网易资深测试专家王晓明的测试分享会——“一起打造你想要的QA团队”,以下为笔者做的归纳总结. 重点 1.让测试更加容易做好.不容易测试的代码,不具有健壮性. 2.Ke ...
- Android应用的安全的攻防之战
一.前言 在前两篇破解的文章中,我们介绍了如何使用动态调试来破解apk,一个是通过调试smali源码,一个是通过调试so代码来进行代码的跟踪破解,那么今天我们就这两篇文章的破解方法,来看看Androi ...
- ABAP GET TIME
用来获得应用服务器的时间. 在程序开始运行的时候,sy-uzeit已经被写入内存,不用get time不会刷新 例如: 运行结果: FORM TSTSYS. DATA: i1 TYPE i VAL ...
- TTradmin v1.1 - 免端口映射穿透任何内网、基于radmin核心的即时远程协助
TTradmin 是一款免端口映射可直接穿透任何内网,基于radmin核心的即时远程协助软件.在使用的时候只需要保证“协助端”和“被协助端”使用同一个验证码即可实现安全便捷的远程控制,不需要进 ...
- 【前端】Node.js学习笔记
module.exports 使用方式: // File Name: hello.js function greet() {/*......*/} // 有下面这两种写法: // 1. module. ...
- React Native for Android 学习笔记
C:\Users\Vic Lee\AwesomeProject>react-native run-android Starting JS server... Running D:\Android ...
- GOLANG 基本数据类型 整型
基本数据类型-整型 种类 有符号(负号) int8 int16 int32 int64 无符号(无符号) uint8 uint16 uint32 uint64 架构特定(取决于系统位 ...
- Android Studio 基本使用
一 . 目录结构: 目录结构本身代表了一个workspace空间 Android stuido是单工程的开发模式 Android stuido里面project表示工作空间,相当于eclipse里面的 ...
- [OC] 图片平铺
Tip: self.bgImg.image = [self.bgImg.image resizableImageWithCapInsets:UIEdgeInsetsMake(100, 40, 40, ...