浅谈闭包,原型链,面向对象

闭包:

百度百科:
官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。

闭包的特点:
  1.作为一个函数变量的一个引用,当函数返回时,其处于激活状态。
  2.一个闭包就是当一个函数返回时,一个没有释放资源的栈区。
  简单的说,javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。

这样看起来是不是更太好懂了
那我们先来看一个例子

function closure(){
  var str = "I'm a part variable.";
    return function(){
  alert(str);
  }
}
var fObj = closure();
fObj();

在这里很明显是在函数里写函数,但是这样就算是闭包了吗?并不是,那只是单纯的写两个函数有什么作用呢?所以,闭包的作用是什么?
1、保证函数内部的变量(属性)不受污染
难道不用闭包变量和属性就会受到污染吗?
你猜!
在es面世之前,js是没有块级作用域的,那么就会有一个问题,我和你的代码合并,变量会不会冲突?答案是变量会覆盖,在es6之前我们都是用var来定义变量的,var的特点是什么呢?可重复,会有变量提升,这里说的覆盖其实就是我们说的收到了污染。当变量收到污染的时候我们该怎么做?
2、函数外部可以调用到函数内部的变量(属性)
这个时候我们需要一个叫做“作用域”的功能,这个时候我们就发现函数能做到这一点,函数能保证我的变量不受污染,那我们又该怎样使用这个不收到污染的变量或者属性呢?很简单,一个return,把你在函数外想调用的东西“弹”出去就好了。
看到这里是不是瞬间感觉两个函数在一起的作用那么厉害,事情有好的一面就会有不好的一面,下面播报一条关于闭包的负面新闻:

由于某程序猿在代码中多次使用闭包导致内存泄漏

闭包那么好,为什么还会导致内存泄漏呢?
浏览器很喜欢收纳函数,所以当运行时出现的函数都会存在内存中,直到浏览器彻底承担不起函数的个数,这个时候就会产生内存泄漏。

原型链

百度百科:
没找到~~
说到原型链,那就先说一下原型
原型:一个对象具有prototype和constructor ,这样就可以说这个对象是原型
原型链:当对象可以被称之为一个原型的时候,每个原型又可以追溯自己的原型对象,然而原型对象又是一个对象,所以它也可以称之为原型,那就又可以找自己的原型对象,就这样一直追溯到null这个结果才会终止,从对象到null的这一段一段的关系,我们可以称之为原型链。
一张图解释一下:!


原型链.jpg

比如我创建一个函数

function foo(){};

这个函数我们可以有两种方法处理

var a=foo();
var b=new foo();

第一种我们一般称之为调用函数。
第二种就叫做实例化对象
在实例化的对象上我们可以为它扩展很多东西,那这个时候就会用到原型链
例如:

foo.prototype.={
  say:function(){}
}

现在就可以在实例化对象之后继续去封装内部的方法了
对于如何访问对象中的属性和方法,谷歌和火狐大大都提供了proto来帮助我们查询。

面向对象

万物皆对象~~
好像是程序猿被问到什么是对象时内心最想丢出去的话~但是又碍于逼格还要好好解释一下什么是对象。

对象:就是具体的一个东西,比如说你刚刚吃掉的一个馒头或者一粒米饭都可以说是一个对象,对象又具有自己的属性和方法,比如说这个米是熟的,这就是一个属性。
这里又不得不说类。

类:刚才说你吃掉的一粒米饭是对象,那如果只说米饭,这就可以说是一个类
所以也可以说,对象是具体的一个,类是一堆对象的集合
所以说面向对象其实是一个很抽象,很大的话题

面向对象的特性
三大特性:继承,封装,多态

继承:可以说是父子关系,儿子具有爸爸的特征,但是儿子也具有自己的特征,在javascript里实现继承大多都会用的原型,可以参考原型链的话题,我们先在一个对象里写了自己的方法,然后另一个对象也可以使用这个对象的方法和属性,并可以拓展自己的方法和属性,这样我们就可以称之是一个实现继承的例子

封装:每个对象都有自己的属性和方法,比如说程序猿他长得很好看这是一个属性,它会敲代码,这是一个方法,那至于他敲代码用的谁的键盘,敲了什么代码,这些细节的东西都被封装起来,我们只知道他会敲代码。

多态:那就说一下封装里的具体内容,比如说程序猿可以用你的代码敲‘hello word’,也可以用我的键盘敲一段‘你好’,这样的同一个封装,造就了不一样的结果,我们称之为多态。
从概念上我们理解了继承、封装、多态,来试着实操一下

继承
//爸爸
function parent(eye,likeFood){
    this.eye=eye;   
    this.likeFood=likeFood;
}
parent.prototype.exercise(){
    console.log('like football');
}

//儿子获取到爸爸的属性
function son(eye,likeFood,mouth){
        parent.call(this,eye,likeFood);//构造函数伪装   调用父级的构造函数--为了继承属性
        this.mouth=mouth; //儿子自己的属性
}
//儿子获取到爸爸的方法
for(attr in parent.prototype){
       son.prototype[attr]=person.prototype[attr];
}
//儿子自己的方法
son.prototype.doing=function(){
         console.log('写作业')
 }
var op=new parent('黑色','鱼');  //爸爸有黑色的眼睛,喜欢的食物是鱼
var os=new son('黑色','蔬菜','小');  //儿子也是黑色的眼睛,喜欢的食物是蔬菜,嘴巴是小的
op.eye();  //黑色
op.likeFood();  //鱼
os.eye();  //黑色
os.likeFood();  //蔬菜
os.mouth();  //小
封装
function createObj(name,key,res){
      var Obj=new Object();
      obj.name=name;
      obj.age=age;
      obj.res=function(){
         alert(res);  
}
      return obj;
}

   var obj1=createObj('程序猿','你的键盘','Hello Word');
   var obj2=createObj('程序猿','我的键盘','你好');

   obj1.name();  //'程序猿'
   obj1.key();    //你的键盘
   obj2.key();  //‘我的键盘’
   obj2.res();    //‘你好’

我们利用封装同时也解释了多态。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容

  • 0 写在前面的话 大多数的面向对象编程语言中,比如C++和Java,在使用他们完成任务之前,必须创建类(class...
    自度君阅读 992评论 0 3
  • 博客内容:什么是面向对象为什么要面向对象面向对象编程的特性和原则理解对象属性创建对象继承 什么是面向对象 面向对象...
    _Dot912阅读 1,410评论 3 12
  • 本文是针对刚学编程的小白,都是一些基础知识,如果想了解更多深层一点的东西,欢迎移步本人博客!! 博客地址 点击跳转...
    西巴撸阅读 221评论 0 0
  • JavaScript对象的理解 ​ 所谓对象就相当于是一个集合, 集合里面可以有属性 , 函数 , 而每一个属...
    一岁一枯荣_阅读 592评论 3 12
  • 函数和对象 1、函数 1.1 函数概述 函数对于任何一门语言来说都是核心的概念。通过函数可以封装任意多条语句,而且...
    道无虚阅读 4,551评论 0 5