前  言

JRedu

 学过程序语言的都知道,我们的程序语言进化是从“面向机器”、到“面向过程”、再到“面向对象”一步步的发展而来。类似于汇编语言这样的面向机器的语言,随着时代的发展已经逐渐淘汰;而面向过程的语言也只有C语言老大哥依然坚挺;现在主流的语言(例如Java、C++、PHP等)都是面向对象的语言。 而我们的JavaScript语言,恰恰介于面向过程与面向对象之间,我们称它为“基于对象”的语言。但是,JS中的OOP依然是我们学习JS的重要一环,当然像“继承”“封装”这样的面向对象特征,都是由模拟实现的。今天,我们就一起来探讨一下JS中的面向对象吧!

 本章内容将详细介绍Android事件的具体处理及常见事件。

一、面向对象概述

1.1面向过程与面向对象

面向过程:专注于如何去解决一个问题的过程。编程特点是用一个个函数去实现过程操作,没有类与对象的概念;

[举个栗子]

当你想吃一个鸡蛋灌饼的时候,面向过程的思维需要你掌握购买食材、和面、烙饼、煎蛋等一系列的方法,然后按照顺序一个一个方法的去执行。

面向对象:专注于有哪一个对象实体去解决这个问题。编程特点是:出现了一个个的类,由类去生成对象。

[举个栗子]

还是想吃鸡蛋灌饼,按照面向对象的思维,你需要去找一个买鸡蛋灌饼的阿姨,让他给你做一个。 这时候,这个阿姨就是我们解决这个问题的对象。

1.2面向对象三大特征

继承、封装、多态

1.3类&对象的关系

① 类:一群有相同特征(属性)和行为(方法)的集合。

eg: 人类  属性:身高、体重、年龄   方法:吃饭、说话、敲代码

② 对象:从类中,拿出的具有确定属性值和方法的个体;

eg: 张三  属性:身高180 体重180  方法:说话--我叫张三

③ 类和对象的关系

类是抽象的,对象是具体的。(类是对象的抽象化,对象是类的具体化)

通俗的来讲:类是一个抽象的概念,表示具有相同属性和行为的集合,但是类仅仅表明这类群体具有相同的属性,但是没有具体的属性值。而对象是对类的属性进行具体赋值后,而得到的一个具体的个体;

[举个栗子]

人类有身高、体重、年龄,但是不能说人类的身高是多少。

而张三,是人类的一个具体个体,身高、体重都有具体值,那么张三就是人类的一个对象

二、JavaScript中的面向对象

2.1创建类和对象的步骤

① 创建一个类(构造函数)。 类名,必须要每个单词的首字母都大写

 funtion 类名(属性一){
                  this.属性=属性一;
                this.方法=function(){}
                 // this指向谁? -- 即将调用当前构造函数的对象。
         }

② 通过类,实例化出一个新的对象;

 var obj = new 类名(属性一的Value);
                 // 原构造函数中this,指向新创建的obj对象;
         obj.方法(); 调用方法
         obj.属性; 调用属性

2.2内创建类和对象代码示例

// ① 定义一个类(构造函数)
        function Person(name,age,sex){
            // 类的属性
            this.name = name;
            this.age = age;
            this.sex = sex;

            // 类的方法
            this.say = function(){
                alert("我叫"+this.name+";今年"+this.age+"岁;是一个"+this.sex+"生");
            }
        }

        // 从类中,实例化出一个对象。并给对象的属性赋值
        var zhangsan = new Person("张三",18,"男");
        //zhangsan.say();

        var lisi = new Person("李二狗",16,"男");
        //lisi.say();
三、JavaScript中的this指向问题

在上一部分中,我们创建了一个类,并通过这个类new出了一个对象。 但是,这里面出现了大量的this。 很多同学就要懵逼了,this不是“这个”的意思吗?为什么我在函数里面写的this定义的属性,最后到了函数new出的对象呢??

今天,就让我们拨开迷雾,牢牢记住“杰小瑞this五大准则”。帮你缕清关于JS中this指向的一切谜团。

3.1谁最终调用函数,this指向谁

首先来明白this指向的基本概念,“this永远指向函数的最终调用者”,理解这句话,我们先明确三个基本要素:

① this指向的,永远只可能是对象!!!!!!

② this指向谁,永远不取决于this写在哪!!而是取决于函数在哪调用。

③ this指向的对象,我们称之为函数的上下文context,也叫函数的调用者

可能有同学要说了,我明确了这三个要素了,我也看不懂this的指向啊。 var obj = new function(); 第二部分的这句话,怎么就让函数(类)中的this指向obj了啊?一脸懵逼ing。。。

那么,接下来,就让我们祭出“杰小瑞this五大法宝”吧!记住这5条,所有this指向手到擒来!

3.2※※※this指向的规律(杰小瑞this五大准则)

首先,我们写这样的一个函数:

function func(){
    console.log(this);
}

Question请问this指向谁

如果面试有人这么问你!你可以直接甩他一个大嘴巴!然后大声告诉他“this指向谁,取决于谁调用函数!而不取决于函数写在哪里!只有函数声明,没有函数调用语句。我不知道this指向谁!

然后,面试官一定会捂着脸告诉你,“你被录用了/(ㄒoㄒ)/~~”

哈哈,开完玩笑,我们来研究一下,下面那个函数中的this,到底有可能指向谁?杰小瑞老师总结了5大准则,一起来看看吧~~

① 通过函数名()直接调用:this指向window

func(); // this--->window
//【解释】 我们直接用一个函数名()调用,函数里面的this,永远指向window。

② 通过对象.函数名()调用的:this指向这个对象

// 狭义对象
    var obj = {
        name:"obj",
        func1 :func
    };
    obj.func1(); // this--->obj
//【解释】我们将func函数名,当做了obj这个对象的一个方法,然后使用对象名.方法名, 这时候函数里面的this指向这个obj对象。

    // 广义对象
    document.getElementById("div").onclick = function(){
        this.style.backgroundColor = "red";
}; // this--->div
//【解释】对象打点调用还有一个情况,我们使用getElementById取到一个div控件,也是一种广义的对象,用它打点调用函数,则函数中的this指向这个div对象。

③ 函数作为数组的一个元素,通过数组下标调用的:this指向这个数组

var arr = [func,1,2,3];
arr[0]();  // this--->arr
//【解释】这个,我们把函数名,当做数组中的一个元素。使用数组下标调用,则函数中的this将指向这个数组arr。

④ 函数作为window内置函数的回调函数调用:this指向window

setTimeout(func,1000);// this--->window
//setInterval(func,1000);
//【解释】使用setTimeout、setInterval等window内置函数调用函数,则函数中的this指向window。

⑤ 函数作为构造函数,用new关键字调用时:this指向新new出的对象

var obj = new func(); //this--->new出的新obj
//【解释】这个就是第二部分我们使用构造函数new对象的语句,将函数用new关键字调用,则函数中的this指向新new出的对象。

3.3综合小练习

没学得会,练习来校对! 上述的五大准则你理解了吗?让我们来做几个小练习吧?看看这些this都是指向谁?

var obj1 = {
            name:'obj1',
            arr:[setTimeout(func,3000),1,2,3]
        }
        document.getElementById("div").onclick = obj1.arr[0];
        // 函数最终调用者:setTimeout ,符合规律⑤ this--->window

        var obj2 = {
            name:'obj1',
            arr:[func,1,2,3]
        }
        document.getElementById("div").onclick = obj2.arr[0]();
        // 函数最终调用者:数组下标 ,符合规律③ this--->arr

        var obj3 = {
            name:'obj1',
            arr:[{name:'arrObj',fun:func},1,2,3]
        }
        document.getElementById("div").onclick = obj3.arr[0].fun();
    // 函数最终调用者:{name:'arrObj',fun:func} ,符合规律② this--->obj

3.4模拟面试题

小练习都做出来了吗?不要骄傲哦~~来看一套模拟面试题吧!!下面的打印语句都应该是什么结果呢?先不要看答案,自己做一下吧~

var fullname = 'John Doe';
        var obj = {
           fullname: 'Colin Ihrig',
           prop: {
              fullname: 'Aurelio De Rosa',
              getFullname: function() {
                 return this.fullname;
              }
           }
        };
        var arr = [obj.prop.getFullname,12,3,4,5];
        console.log(arr[0]());//this指向数组,数组没有fullname属性,所以未定义!
        console.log(obj.prop.getFullname()); // Aurelio De Rosa
        //函数最终调用者:obj.prop  this--->obj.prop
        var test = obj.prop.getFullname;
        console.log(test());  // John Doe
        // 函数最终调用者: 函数() window  this-->window
        obj.func = obj.prop.getFullname;
        console.log(obj.func()); // this最终调用者是obj,所以this指向obj

好了,通过本篇博客,我们了解了什么是面向对象、类和对象的关系、JS中声明类与对象的步骤,以及重点讲解的this指向问题! 希望能够帮助大家真正的理解了this的认知,接下来的博客让我们继续探讨JavaScript的面向对象。

作者:杰瑞教育
出处:http://www.cnblogs.com/jerehedu/ 
版权声明:本文版权归烟台杰瑞教育科技有限公司和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

技术咨询:

JavaScript面向对象(一)——JS OOP基础与JS 中This指向详解的更多相关文章

  1. OOP中this指向详解

    谁调用了函数,this就指向谁 >>> this指向的永远只可能是对象!!! >>> this指向谁,永远不取决于this写在哪,而是取决于函数在哪调用!!! &g ...

  2. JavaScript面向对象(三)——继承与闭包、JS实现继承的三种方式

      前  言 JRedu 在之前的两篇博客中,我们详细探讨了JavaScript OOP中的各种知识点(JS OOP基础与JS 中This指向详解 . 成员属性.静态属性.原型属性与JS原型链).今天 ...

  3. 面向对象(OOP)--OOP基础与this指向详解

      前  言            学过程序语言的都知道,我们的程序语言进化是从“面向机器”.到“面向过程”.再到“面向对象”一步步的发展而来.类似于汇编语言这样的面向机器的语言,随着时代的发展已经逐 ...

  4. js插件---videojs中文文档详解

    js插件---videojs中文文档详解 一.总结 一句话总结: js插件网上都有很多参考资料,使用起来也非常简单 二.lavarel中使用实例 <video id="example_ ...

  5. js实现的新闻列表垂直滚动实现详解

    js实现的新闻列表垂直滚动实现详解:新闻列表垂直滚动效果在大量的网站都有应用,有点自然是不言而喻的,首先由于网页的空间有限,使用滚动代码可以使用最小的空间提供更多的信息量,还有让网页有了动态的效果,更 ...

  6. [概念] js的函数节流和throttle和debounce详解

    js的函数节流和throttle和debounce详解:同样是实现了一个功能,可能有的效率高,有的效率低,这种现象在高耗能的执行过程中区分就比较明显.本章节一个比较常用的提高性能的方式,通常叫做&qu ...

  7. main.js index.html与app.vue三者关系详解

    main.js index.html与app.vue三者关系详解 2019年01月23日 11:12:15 Pecodo 阅读数 186   main.js与index.html是nodejs的项目启 ...

  8. Javascript中prototype属性详解 (存)

    Javascript中prototype属性详解   在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不 ...

  9. 【JavaScript中的this详解】

    前言 this用法说难不难,有时候函数调用时,往往会搞不清楚this指向谁?那么,关于this的用法,你知道多少呢? 下面我来给大家整理一下关于this的详细分析,希望对大家有所帮助! this指向的 ...

随机推荐

  1. JS - dateFormat

    // date必填, pattern默认'yyyy-MM-dd HH:mm:ss'function dateFormat (date, pattern) { var week = {'0':'日', ...

  2. php 批量进行复制文件

    php 批量进行复制文件 1.前言 目标:php批量进行复制指定的目录文件夹下所有文件复制到另一个文件夹下 所使用的的php函数:is_dir,opendir,readdir,scandir,mkdi ...

  3. 支持多个版本的ASP.NET Core Web API

    基本配置及说明 版本控制有助于及时推出功能,而不会破坏现有系统. 它还可以帮助为选定的客户提供额外的功能. API版本可以通过不同的方式完成,例如在URL中添加版本或通过自定义标头和通过Accept- ...

  4. 扩展entity framework core 实现默认字符串长度,decimal精度,entity自动注册和配置

    报道越短,事情越严重!文章越短,内容越精悍! 文章以efcore 2.0.0-preview2.测试验证通过.其他版本不保证使用,但是思路不会差太远.源代码 目标: 1.实现entity的自动发现和m ...

  5. (转)Eclipse快捷键 10个最有用的快捷键

    1 Eclipse中10个最有用的快捷键组合 一个Eclipse骨灰级开发者总结了他认为最有用但又不太为人所知的快捷键组合.通过这些组合可以更加容易的浏览源代码,使得整体的开发效率和质量得到提升. 1 ...

  6. JARVIS 手机监控局域网内PC

    JARVIS 通过反向的Socket连接,实现通过手机(或任何可以发送Http请求的设备)对局域网内PC的监控.在外时可以远程监视家里PC任务的执行情况,甚至远程唤醒家里的PC提前打开游戏也可以实现( ...

  7. ES6字符串扩展

    前面的话 字符串是编程中重要的数据类型,只有熟练掌握字符串操作才能更高效地开发程序.JS字符串的特性总是落后于其它语言,例如,直到 ES5 中字符串才获得了 trim() 方法.而 ES6 则继续添加 ...

  8. 如何将R包安装到自定义路径

    参考  设置环境变量R_LIBS将R包安装到自定义路径   实际上是可以解决问题的, #环境变量完成以后,启动(重启)R,运行 .libPaths() 加载R包时,发现路径仍然未变成自定义的. 那么参 ...

  9. 44. leetcode 28. Implement strStr()

    28. Implement strStr() Implement strStr(). Returns the index of the first occurrence of needle in ha ...

  10. 测试与开发如何有效沟通,QC11(HP ALM 11)的简单使用记录

    笔者所在的项目组使用的缺陷管理工具是HP的QC11,作为测试人员,为了与开发一起跟随Bug的一生,简单的写了使用流程,这里记录一下,主要是让开发人员熟悉一下. 首先使用账户登录QC,如地址: http ...