zoukankan      html  css  js  c++  java
  • 浅谈:javascript的面向对象编程之基础知识的介绍

    在进入javascript的面对对象之前,我们先来介绍一下javascript的几个概念。

    1、javascript的面向对象的基本概念

    function aa(){
        
    }
    
    /*
     * 这里的aa,在我们以前看来他是一个函数,确实如此,但是从现在的角度来看
     * aa不仅仅是一个函数,他还是一个对象。在javascript中,一切都是对象,函数也不例外
     * 我们可以给对象的属性赋值,例如aa.b = 5,还可以获取对象的值,例如
     * 这种赋值可以直接赋值,不需要声明,直接aa.属性=xxx,即可为aa的某个属性直接赋值
     * alert(aa.5)。
     */
    aa.b = 5;
    alert(aa.b);
    
    //你也可以这样
    
    function bb(){
        alert("bb");
    }
    
    aa.d = bb;
    aa.d();//在网页上显示bb
    /*
     * 通过上面的例子我们可以发现,aa这个对象(函数)的属性不仅可以是普通的变量
     * 也可以是对象属性。bb也是一个对象,bb也可以成为aa对象的一个属性
     * 和java的属性类似,属性既可以是普通类型,也可以是引用类型
     */
    
    
    //你还可以这样,创建一个json格式的对象,把json格式的对象放入对象aa中
    
    var json ={//创建一个json格式的对象
            "name":"zhangSan"
    };
    
    aa.objectJson = json;//让aa中objectJson属性赋值为json
    alert(aa.objectJson.name);//在网页上可以看到zhangSan
    
    
    /*
     * 在aa对象(函数)中,aa里面的属性可以是普通变量,函数(对象类型),也可以json格式的对象等等
     */

    2、javascript的返回值

    /*
     * js函数的返回值
     * 我们之前见到的js返回的都是一个变量
     */
    
    function fun(){
        return 5;
    }
    
    alert(fun());
    
    
    /*
     * 但是,由于我们明确了对象的概念,所以返回值当然也可以是对象
     * 在函数(对象)内部定义函数
     */
    
    function cc(){
        var i=0;
        function dd(){
            i++;
            return i;
        }
        
        return dd;//返回值变成了一个对象
    }
    
    
    //调用函数
    var cfun = cc();
    alert(cfun());//显示1
    
    
    /*
     * 下面我们来做一个练习来帮助我们理解js的返回值
     * 需求:调用一个Person函数,返回一个对象,该对象中有setPid,getPid,setPname,getPname方法
     * 
     * 分析:可以这么去理解。返回一个json格式的对象,在json格式对象里面
     * 使用键值对的方式,只不过键是函数(对象)
     */
    
    function person(){
        return{
            setPid:function(pid){
                this.pid = pid;
            },
            
            getPid:function(){
                return this.pid;
            },
            
            setPname:function(pname){
                this.pname = pname;
            },
            
            getPname:function(){
                return this.pname;
            } 
        };
    }
    
    var p = person();
    
    //使用对象的属性方法
    p.setPid("2");
    p.setPname("zhangSan");
    alert(p.getPid());
    alert(p.getPname());

    3、javascript原型的概念

    function person(){
        
    }
    
    function student(){
        
    }
    
    /*
     * 这个属性a只是person对象私有,但是student对象并没有该属性,
     * 如果想让student有person的属性,怎么办呢?
     * 
     * 这个时候,就需要引入原型(prototype)的概念
     * 
     * 原型是什么:原型是一个对象,其他对象可以通过它实现属性继承。
     * 任何一个对象都有原型吗?:是的
     *
     * 
     * 哪些对象有原型
        所有的对象在默认的情况下都有一个原型,因为原型本身也是对象,
        所以每个原型自身又有一个原型(只有一种例外,默认的对象原型在原型链的顶端。更多关于原型链的将在后面介绍)
     */
    person.a = 5;
    
    /*
     * 如果student想要person对象的属性
     * 我们上面说过,一个函数,他是对象,
     * 在这里一个函数也是一个构造器函数,通过下面的例子可以看出,student也是一个构造器函数
     * var s = new student();
     * 
     */
    
    student.prototype = person;//把person的原型属性给了student的原型
    var s = new student();
    alert(s.a);//在创建student对象的时候,就可以使用原型里面的属性了
    
    
    
    
    function man(){
        
    }
    /*
     * 我们可以打印出一下man这个对象的构造器,下面的就是man的构造器
     * function Function() {
            [native code]
        }
     */
    alert(man.constructor);//上面注释中的结果
    
    /*
     * 我们也可以给原型进行这样的赋值
     * 也就是说,man原型可以是一个json类型的对象
     */
    
    man.prototype = {
            aa:function(){
                
            },
            
            bb:function(){
                
            }
    };
    
    /**
     * 对原型的总结:
     * 1、任何一个对象都有构造器
     * 2、所有的对象都有原型
     * 3、通过构造器函数.prototype.属性的方法可以给原型添加属性
     */

    4、javascript闭包的概念

    //还是来举个例子
    function person(){
        
    }
    
    person.a=5;
    /*
     * 我们知道,a是person对象的一个属性,但是这个person对象的属性a
     * 使用者都可以访问,而且还可以修改a的属性值
     * 但是如果我定义了一个对象,有一些属性很重要,我不想让外部去修改他,怎么办?
     * 这就需要使用到闭包。
     * 
     * 对闭包的理解和说明
     *     1、在函数内部定义的函数或者变量无法在外面访问
     *  2、在外部访问函数内部函数或者变量的过程叫做闭包
     *  3、闭包很消耗内存,因为变量不会因为函数的销毁而销毁
     *  4、使用闭包使函数和变量具有了私有属性
     *  5、闭包有闭包的范式
     *  
     *  闭包的范式:首先是两个大括号()() 前一个大括号里面放一个匿名函数,后一个大括号里面放一个实参
     *              形参和实参对应,在匿名函数中,都可以使用形参
     *  (function(形参){})(实参),说白了,也就是函数里面放一个或者多个函数
     *  
     *  下面来看具体的例子
     * */
    
    (function(a){
        var i=0;
        function aa(){
            alert("aa");
        }
    })(5);
    
    //alert(aa());//无法访问aa
    
    /*
     * 但是又会出现一个问题,如果对象里面我想提供一些方法,给外界使用,又可以怎么办呢
     * 比如,我想把bb和cc方法给外界访问,怎么办呢?
     * 可以把函数变成实参的一个属性,通过实参的属性来进行调用
     * 说白了,就是在形参中把私有属性添加成形参的属性
     * 在外界通过实参获取属性(私有方法),进行调用
     * 
     */
    
    (function(a){
        function aa(){
            alert("aa");
        }
        
        function bb(){
            alert("bb");
        }
        
        
        function cc(){
            alert("cc");
            
        }
        
        /*
         * 在a(window)对象中,有一个openMethod的属性,
         * 在属性中返回了两个函数(对象)
         * 
         */
        a.openMethod = function(){
            return {
                bb:bb,
                cc:cc
            };
        };
        
    })(window);
    
    var jsonMethods = window.openMethod();
    jsonMethods.bb();//bb
    jsonMethods.cc();//cc
    
    /*
     * 闭包所解决的问题:
     * 1、解决了js面向对象过程中私有属性和私有对象的问题
     * 2、在函数内部定义的函数可以在函数外部使用
     */

    如果你打开jQuery的代码,你会发现他使用的就是闭包

    5、jQuery插件的制作

    说到jQuery,是一个功能很强大的插件,而且使用的方法也很简单,但是有些时候,他提供的方法或许并不能使我们满意

    那我们能不能在jQuery基础上,定义自己的插件,用来针对我们自己的项目,答案是可以的。

    在制作插件之前,我们先来解析一下jQuery

    在jQuery的最外层,是一个闭包。

    //jQuery最外层是一个闭包
    (function( window, undefined ) {
        
      var jQuery = function( selector, context ) {
            // The jQuery object is actually just the init constructor 'enhanced'
            return new jQuery.fn.init( selector, context );
        .....
        //相当于把jQuery当做一个window对象的属性,在外部通过window.Jquery来访问,可以推出$=jQuery
        ......

        window.jQuery = window.$ = jQuery;
            
    }, })(window);
    //jQuery 就是一个很普通的函数,也是一个对象,还是一个构造函数

    现在大家终于明白闭包的重要性了吧,jQuery都使用闭包,想想看闭包是有多重要

    我们以前使用jQuery大概有这么两种使用方法

    $("#xx").val()

    或者是

    $.post();

    对于第一种使用方法,首先获取到一个对象,然后使用对象.val()来使用具体方法

    对于第二种方法,直接$.post(),并没有依赖域任何对象,直接使用

    所以就产生了两种不同类型的方法,原型方法和全局方法

    原型方法就是针对某写对象设计的,首先需要获取到jQuery对象,然后对象.xx方法

    全局方法就是不依赖于任何对象,直接可以调用。

    所以我们制作jQuery插件就有了两种方法,一是制作原型方法,而是制作全局方法

    原型方法定义的规则:

    $.fn.aa = function(){}  说明:$.fn = $.prototype

    这里的aa就是原型方法(在jQuery原型上定义的方法)

    其实在jQuery内部也是这么定义方法的

    附:jQuery内部的部分代码,可以看出jQuery内部也是这么定义原型方法

    全局方法定义规则:

    $.alert =function(msg){window.alert(msg)}

    全局方法不需要经过对象,直接定义即可。

    上面就是定义jQuery插件的方法,其实很简单,就把jQuery当做一个对象,并且把定义在原型上面的方法称为原型方法,属性方法称为全局方法

    上面介绍的几个概念我也只是简单的说了一下,如果说的不够详细,大家可以去网上看看视频或者参考书或者搜一搜资料

    上面的几个概念对javascript面向对象编程很重要,希望大家可以花点心思去弄懂。

  • 相关阅读:
    bzoj2763 [JLOI]飞行路线 分层图最短路
    [模板]分块/可修改莫队 (数颜色种类)
    gcd步数
    洛谷2378 因式分解 字符串
    bzoj1090 字符串折叠
    洛谷1034 NOIP2002 矩形覆盖
    Codeforces#441 Div.2 四*题
    SPFA的小优化
    洛谷1073 NOIP2009 最优贸易
    bzoj2100 [Usaco2010 DEC]Apple Delivery苹果贸易
  • 原文地址:https://www.cnblogs.com/yghjava/p/5763951.html
Copyright © 2011-2022 走看看