码迷,mamicode.com
首页 > 其他好文 > 详细

24)

时间:2018-11-01 22:33:34      阅读:250      评论:0      收藏:0      [点我收藏+]

标签:var   array   cto   tor   公有   之间   define   形式   代码   

js数据类型:

基本数据类型:string undefined null Boolean number

引用数据类型:object array function

二者区别:

  基本数据类型就是简单的赋值

  引用数据类型就是把引用地址赋值给变量

堆内存:

  就是存放代码块的,存放有两种形式:

                一是对象以键值对形式存放

                二是函数,以字符串形式存放

引用数据类型的赋值,是把引用地址赋值给他,在修改属性的时候,通过地址查找然后改掉

应用数据类型,如何操作?

  先通过引用地址去查找堆内存中的代码,然后去修改

This研究在函数内部:

  在js中的函数形式的种类:

    1.普通函数:function fn(){}   var fn=function()

    2.类

对象 Object

  对象里面的数据以键值对的形式存在,跟json一样

  一。单例模式

    作用域和堆内存区别:

        作用域是函数执行时候产生的fn()

        函数执行的时候,首先会开辟一个新的内存空间叫栈内存(环境,作用域)

        数据类型在赋值的时候回开辟一个新的内存空间叫堆内存(存放代码块的)

        二者都会形成一个内存地址

    生成对象的单例模式:

        优势——每个对象都是独立的,即便属性起的名字一样,不会相互干扰,方便现在流行的开发模式“模块化开发”

            如需要使用里面的属性,用.运算符,如zhang.name或zhang[ “name”]

            判断一个属性是不是这个对象的,用in运算符,如“name”in zhang 

            如遍历这个对象,用for (attribute    in    zhang){}

  二。工厂模式——对象

        function Creayifu(name,age){

            var obj={
              "name":name,
              "age":age
             }
             return obj;
        }
        var zhang=Creayifu("张三",23)
        var li=Creayifu("李四",23)
        console.log(li)

        这种形式我们叫函数封装

      优势:可以批量生产,减少代码冗余,提升代码重复利用率(高密度耦合)。没有继承和多态

  三。构造函数——对象

    要求: 1,函数的首字母必须大写

        2.里面的属性亲前面必须加this

        3.函数调用的时候,必须用new关键字

        function Person(name,age){

                this.name=name;
                this.age=age
        }
        var zhang=new Person("张三",23)
        console.log(zhang)

        我们把Person叫类  zhang叫实例

        对象的特征有属性和方法

        构造函数里面的this指向实例的对象

        构造函数里有了类和实例的概念,并且实例和实例都是独立的个体,我们把他叫做实例识别

        构造函数里面的属性都是私有的,各个实例对象之间没有公共属性

  为了实例的对象拥有公共属性,所以js使用了prototype(原型),这个属性,属性值是一个对象,我们可以把公共的属性放在这个prototype上

  原型分析:

    1.每个函数数据类型(普通函数,类)都有一个Prototype属性,并且这个属性是一个对象数据类型

    2.每个prototype上都有一个constructor属性,并且这个属性值是当前函数或类本身

    3.每一个对象数据类型(实例,普通对象,prototype)都天生具有一个__proto__属性,他的属性值是当前实例所属类的原型   

      function Person(name,age){
              this.name=name;
              this.age=age
              }
      Person.prototype={
              xx:"你好",
              say:function(){
                  console.log(123)
                }
       }
      var zhang=new Person("zhangsan",11)
      var li=new Person("lisi",12)

原型链:

   duixiang.shuxing的时候,首先看这个属性是不是私有的,私有的就直接使用,如果私有的属性没有,就找公有的,没有就按照--proto--找她身上的类有没有,直到找到基类object。如果object没有,就undefined,这种查找机制叫原型链。

24)

标签:var   array   cto   tor   公有   之间   define   形式   代码   

原文地址:https://www.cnblogs.com/xiaotaiyangye/p/9892359.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!