本篇主要分享我对闭包的理解及使用闭包完成私有属性、模拟类、继承等,结合大量例子,希望大家能快速掌握!首先让我们先从一些基本的术语开始吧
 
 
一、javascript中的闭包
1、我们一起先来理解什么是函数的作用域。

2、调用的对象

结合例子:

复制代码
代码如下:
function display(something)
{

function executeDisplay1()
{

document.write("我在帮老板打印:"+something+"<br />");//引用外部函数的something参数

}
executeDisplay1();//函数display引用了内部函数
}

display("sorry");//执行完毕后被垃圾收集器回收

3、闭包的形成

例一、

复制代码
代码如下:
var obj = {};//全局的对象
function
buyHouse(price,area)
{
return function(){return "你要付的房款:"+price*area;};
//把内部函数作为返回值
}
obj.people = buyHouse(12000,80);
//把内部函数的引用保存到obj对象的people属性中。

//这样就形成了闭包,简单的表达:把嵌套函数的引用保存到全局作用域中,不管是使用它返回的值,还是把它存在对象的属性中都可以。

document.write(obj.people()+"<br />");

例二、

复制代码
代码如下:
function add()
{
var number = 0;

return function(){return ++number;};//
}
var num =
add();//现在是不是有4引用了吧,第一个全局创建:访问函数,第二个有外部函数(这里指的是Add()引用了匿名函数)

//第三个是匿名函数(就是return function.....引用了Add的局部变量),第四个就全局对象(var num)了。

//全局对象的每次调用的对象依然保存在函数体中,所以局部变量的值都会被维持。
document.write(num());

//等效的方法
num2 = (function(){var number = 0;return function(){return
++number;}})();//匿名函数,直接赋给了全局对象
document.write(num2());

例三、实现私有属性

复制代码
代码如下:
//使用闭包实现私有属性
function
createProperty(o,propertyname,check)
{
var value;

o["get"+propertyname] = function(){return value;};//将一个匿名的函数体返回给对象的属性

o["set"+propertyname] = function(v){if(check &&
!check)//检查参数的合法性throw("参数不对!");
else value = v; };//将一个匿名的函数体返回给对象的属性
}

var o = {};
createProperty(o,"Age",function(x){return typeof x ==
"number";});//后面跟了一个匿名的函数,执行验证的工作,如果不是数字就返回false
o.setAge(22);//使用对象的属性

document.write(o.getAge());

//其实上面还是将函数保存到了全局对象的属性中。

二、javascript中的类
同样也从一些基本的术语开始吧!
1、原型(prototype)

其实一个对象的原型就是构造函数的prototype的值,所有的函数都一个prototype属性,当函数被创建是就被自动创建和初始化,初始化它的值是一个对象,这个对象自带一个属性就是constructor,它指回到和原型相关联的那个构造函数。

复制代码
代码如下:
function PeopleHope(money,house)
{

this.money = money;
this.house = house;
}

PeopleHope.prototype.hope =
function(){document.write("我想拥有钞票,房子");};//这就是原型,都会被构造函数初始化成对象的属性。
for(var p
in PeopleHope.prototype)
{
document.write("原型出来了吧! \t " + p + "<br
/>");//输出:原型出来了吧! hope
}

2、模拟类

其实Javascript中的“类”就是函数而已。直接上代码吧!

复制代码
代码如下:
function PeopleHope(money,house)
{

this.money = money;
this.house = house;
PeopleHope.VERSION =
0.1//类的属性
PeopleHope.createLive =
function(){document.write("在党的领导下,我们的生活很好!");}//类方法 必须是类直接引用
}

3、类的继承

复制代码
代码如下:
function CreateClass(name,version)
{

this.name = name; //初始化对象属性
this.version= version;

CreateClass.AUTHOR = "Frank";//类属性
CreateClass.SellHouse =
function(){document.write("我们是房地产龙头企业万科");};//类的方法

CreateClass.prototype.Company = "vanke";

CreateClass.prototype.HousePrice =
function(){document.write("大梅沙山顶豪宅卖5千万一套,畅销价!");};

//原型,其实到这里大家可能就会问了,这个原型和类方法等有什么区别呢?
//其实就是:比如 var o = new
CreateClass("中粮地产","一期");CreateClass函数里面的this就是o了,连起来就是
//o.name =
"中粮地产";o.version = “一期”;吧!
//至于原型其实在干的事你可以把它理解成一个”叛徒“在你创建o这个对象的时候,由
原型告诉构造函数一起带走初始化
//成了对象o的属性。
}
function House(name,version,city)

{
CreateClass.apply(this,[name,version]);//继承构造函数
this.city = city;

House.prototype.housename = "半岛花园";
}
House.prototype = new
CreateClass("中粮地产","二期");//通过new获取CeateClass属性,包括原型对象
//打印函数的prototype属性

function displayPrototype(c)
{
for(var x in c.prototype)
{

document.write(x+"<br />");
}
}

displayPrototype(House);//输出:HousePrice Company name version
//删除不是原型的对象

delete House.prototype.name;//删除
delete House.prototype.version;//删除

displayPrototype(House);//输出:HousePrice Company
var customers = new
House("半岛花园","三期","西拔牙");
for(var t in customers)
{
if(typeof
customers[t] == "function")//判断是不是函数
{
customers[t]();//执行

continue;//返回本次,进行下一次循环
}
document.write(t +":\t" + customers[t]+
"<br />");
// 输出housename: 半岛花园 Company: vanke 大梅沙山顶豪宅卖5千万一套,畅销价!name:
半岛花园version: 三期 city: 西拔牙
//继承就实现了。通过原型。

小结:本篇就和大家分享到这里吧,本来还有命名空间要分享,由于学习时间安排的关系,Javascript语法就给大家分享到这里吧!

下次我将分享我对javascript客服端的编程及Jquery等高级应用。

JavaScript 高级篇之闭包、模拟类,继承(五)的更多相关文章

  1. Javascript高级篇-JS闭包

    Javascript闭包 1.变量的作用域 1.1局部变量 1.2全局变量(声明在外边或不用var来声明的变量) 2.外部读取方法内部的局部(私有)变量 function a(){ var b = & ...

  2. JavaScript高级篇之Function对象

    JavaScript高级篇之Function对象 一: Function对象引入: Function对象是js的方法对象,可以用Function实例化出任何js方法对象. 例如: <%@ pag ...

  3. 在 JavaScript 中使用构造器函数模拟类

    今天,我们要讲的是在 JavaScript 中使用构造器函数(construcor function)模拟类. 构造器函数简介 你可以使用 ES6 的 class 关键字来实现类,不过我建议你使用传统 ...

  4. JavaScript高级内容:原型链、继承、执行上下文、作用域链、闭包

    了解这些问题,我先一步步来看,先从基础说起,然后引出这些概念. 本文只用实例验证结果,并做简要说明,给大家增加些印象,因为单独一项拿出来都需要大篇幅讲解. 1.值类型 & 引用类型 funct ...

  5. Javascript高级篇-面向对象的特性

    一.创建对象 1.1初始化器 var any={ name:"some", age:10, action:function(){ alert(this.name+":&q ...

  6. 《JAVASCRIPT高级程序设计》闭包

    一.闭包的概念 闭包是JAVASCRIPT中最重要的概念之一,闭包是指有权访问另一个函数作用域中变量的函数:创建闭包常见的方式,就是在一个函数内部,创建另一个函数.以下的例子创建了一个闭包,加粗的两行 ...

  7. 读javascript高级程序设计06-面向对象之继承

    原型链是实现继承的主要方法,通过原型能让一个引用类型继承另一个引用类型. 1.原型链实现继承 function SuperType(){ this.superprop=1; } SuperType.p ...

  8. 《Javascript高级程序设计》读书笔记之继承

    1.原型链继承 让构造函数的原型对象等于另一个类型的实例,利用原型让一个引用类型继承另一个引用类型的属性和方法 function SuperType() { this.property=true; } ...

  9. Jmeter(五十) - 从入门到精通高级篇 - jmeter 之模拟弱网进行测试(详解教程)

    1.简介 在实际工作中,网络带宽一定不会是持续稳定的保持某一个值,而是有高有低.因此为了测试场景和实际能够无限的接近,所以我们需要模拟一下来达到效果.还有就是在实际的测试工作中,会因为业务需要,有时限 ...

随机推荐

  1. 2014ACM/ICPC亚洲区广州站 北大命题

    http://acm.hdu.edu.cn/showproblem.php?pid=5131 现场赛第一个题,水题.题意:给水浒英雄排序,按照杀人数大到小,相同按照名字字典序小到大.输出.然后对每个查 ...

  2. winform 按顺序连续打印多个PDF文件

    关于PDF打印的问题,前面有篇文章(点这里查看)也叙述过,今天来谈谈另外一种方法 其实方法很简单,因为需要把多个PDF文档按顺序连续打印,为此我们为什么不把要打印的pdf文档按顺序合并成一个PDF打印 ...

  3. 引擎设计跟踪(九.8) Gizmo helper实现与多国语言

    最近把gizmo helper的绘制做好了. 1.为了复用代码,写了utility来创建sphere, cube, cylinder, plane, ring(line), circle(solid) ...

  4. MAC下搭建web开发环境

    具体做法,参照此链接:http://mallinson.ca/osx-web-development/ Mac系统本身自带apache和PHP,MySQL可以安装也可以不安装 web开发的IDE可以是 ...

  5. struts2漏洞原理及解决办法

    1.原理 Struts2的核心是使用的webwork框架,处理action时通过调用底层的getter/setter方法来处理http的参数,它将每个http参数声明为一个ONGL(这里是ONGL的介 ...

  6. 解决IE不支持position:fixed问题

    #box { /* 非IE6浏览器使用固定元素 */ position:fixed; top:0; left:0; /* IE6改为绝对定位,并通过css表达式根据滚动位置更改top的值 */ _po ...

  7. Win8必知快捷键汇总

    * Win+C:调出应用Charm菜单(开始界面.传统桌面) * Win+D:所有程序最小化,再次按下恢复(开始界面.传统桌面) * Win+E:打开我的电脑(开始界面.传统桌面) * Win+F:调 ...

  8. 支持DISTINCT的通用分页存储过程(SQL2005)

    /****** 对象: StoredProcedure [dbo].[P_CommonPagination] 脚本日期: 07/22/2009 10:22:01 ******/ SET ANSI_NU ...

  9. cf div2 234 D

    D. Dima and Bacteria time limit per test 2 seconds memory limit per test 256 megabytes input standar ...

  10. hdu 4618(最大回文子矩阵)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4618 昨天多校的一道题,说多了都是泪啊,为了一道图论题,磨了那么久,结果是别的题都没看,没办法,补呗. ...