Web-js中级-11月1日
Posted lovels
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Web-js中级-11月1日相关的知识,希望对你有一定的参考价值。
一:
js数据类型
基本数据类型:string undefined null boolean number
引用数据类型:Object array function
二者的区别:
基本数据类型就是简单的赋值。
引用数据类型是把地址赋值给变量。
堆内存
就是存放代码块的,存放形式有两种,一种是对象以键值对的形式存放
另一种就是函数,以字符串的形式存放。
引用数据类型的赋值,是把引用地址赋值给它,在修改属性的时候,通过地址查找然后改掉。
应用数据类型,如何操作?
先通过引用地址去查找堆内存的代码,然后再去修改。
在js中的函数形式的种类
1. 普通函数 function fn(){} var fn=function()
2. 类
对象 Object
对象里面的数据以键值对的形式存在。跟json一样。
二:
面向对象的三种模式:1.单例模式 2.工厂模式 3.构造函数
1.单例模式
我们把变量zhang和li叫“命名空间”
作用域和堆内存的区别
作用域是函数执行的时候会开辟一个新的内存空间叫栈内存 (环境或作用域)
数据类型在赋值的时候会开辟一个新的内存空间叫堆内存(存放代码块的)
二者都会形成一个内存地址。
生成对象的单例模式
优势,每个对象都是独立的,即便属性起的名字一样,不会相互干扰,方便现在流行的开发模式,模块化开发。
如果需要使用里面的属性,用点运算符 如zhang.name或zhang【“name”】,判断一个属性是不是这个对象的用in运算符 如“name”in zhang如果遍历这个对象用 for(attr in zhang){}
缺点,不可以批量生产,只能一个一个的去创建。
2. 工厂模式
这种形式我们叫函数封装。优势,可以批量生产,减少冗余代码,提高代码重复利用率(高密度低耦合)。没有继承和多态。
3. 构造函数
要求: 1.函数名首字母必须要大写 2.里面的属性前面必须加this 3.函数调用的时候必须使用new关键字。
我们把Person叫类 把zhang叫实例。万物皆对象。对象的特征有属性和方法。
string的类是String
数组的类是Array
对象的类是Object
构造函数里的this指向实例对象。
构造函数里有了类和实例的概念,并且实例和实例都是独立的个体,我们把他叫实例识别。
构造函数里面的属性都是私有的,各个实例对象之间没有公有的属性。
为了实例的对象拥有公共的属性,所以js使用了prototype(原型)这个属性,属性值是一个对象,我们可以把他公共的属性放在这个prototype上了。
原型分析
1. 每个函数数据类型(普通函数,类)都有一个propotype属性,并且这个属性是一个对象数据类型。
2.每一个对象数据类型(实例,普通函数,prototype)都有一个叫--proto--的属性,他的属性值是当前实例所属类的原型。
通过图像我们知道zhang.__proto__==Person.protype true
原型链:
Duixiang.shuxing的时候,首先看这个属性是不是私有的,私有的就直接使用,如果私有
的属性没有,就找公有的,公有的有就直接使用,没有就按照——proto——找他的类上有没有,
直到基类Object。如果Object没有就undefined了。这种查找机制叫原型链。
三:
数据的三种存储方式:
1.String “”
2.Array []
3,Json {}
所有的编程语言 java c python c++ 等 他们都是面向对象编程,面向对象必须有三大特点,封装,继承,多态。
以上是关于Web-js中级-11月1日的主要内容,如果未能解决你的问题,请参考以下文章