博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js中级小知识1
阅读量:4456 次
发布时间:2019-06-08

本文共 1720 字,大约阅读时间需要 5 分钟。

 

首先我们复习之前的小知识,本期博客与之前有关

js数据类型

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

    引用数据类型:     Object     array       function

二者的区别

      基本数据类型就是简单的操作值,引用数据类型,把引用地址赋值给变量    

堆内存

  就是存放代码块的,存放形式有两种,一种是对象一键值对的形式存放

  另一种就是函数  以字符串的形式存放

 

 

 案例

 

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

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

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

this研究在函数内部

  在js中的函数形式的种类

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

    2.       类

对象Object

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

  1.  单例模式====>  对象

     

    我们把变量zhang和li叫"命名空间"

作用域和堆内存的区别

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

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

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

生成对象的单例模式

  优势。每一个对象都是独立的,即便属性起的名字一样,不会相互干扰,方便现在流行的开发模式"模块化开发"。如果需要使用里面的属性,用.运算符      如zhang.name或zhang["name"],判断一个属性是不是这个对象的用in运算符  如"name"in zhang        如果遍历这个对象用for(atter in zhang){}.

  缺点,不可以批量生产对象,只能一个一个的去创建。

  2.    工厂模式===》 对象

   

  这种形式我们叫函数封装。优势,可以批量生产,减少冗余代码,提高代码重复利用率

(高密度第耦合)。 没有继承和多态。

3.  构造函数==》 对象

  要求,1.函数名首字母必须大写,

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

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

我们把person叫类。   把zhang叫实例。     万物皆对象。       对象的特征有属性和方法。

string的类是String

数组的类是Array

对象的类是Object

构找函数里的this指向实例对象。

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

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

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

  原型分析

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

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

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

通过这张图我们知道

zhang.__proto__==Person.prototype        true

 

原型链

Duixiang.shuxing的时候,首先看这个属性是不是私有的,私有的就使用,如果私有的属性没有就找公用的,共有的有就是用公有的,没有就按照__proto__找他的类上有没有,直到找到基类Object。如果没有就undefined了。这种查找机制叫原型链。

数据类型的三种存储方式

  1.       String      “”

  2.  Array       []

  3.       Json         {}

所有编程语言java  c      python      c++     等      他们都是面向对象编程,面相对象必须有三大特点,封装,继承,多态。 

如何生成对象。

转载于:https://www.cnblogs.com/guhuai/p/9893297.html

你可能感兴趣的文章
vue-11-路由嵌套-参数传递-路由高亮
查看>>
HDU 1199 - Color the Ball 离散化
查看>>
[SCOI2005]骑士精神
查看>>
Hibernate原理解析-Hibernate中实体的状态
查看>>
六时车主 App 隐私政策
查看>>
C语言常见问题 如何用Visual Studio编写C语言程序测试
查看>>
Web用户的身份验证及WebApi权限验证流程的设计和实现
查看>>
hdu 2098 分拆素数和
查看>>
[ONTAK2010]Peaks kruskal重构树,主席树
查看>>
ECMAScript6-let与const命令详解
查看>>
iOS 使用系统相机、相册显示中文
查看>>
什么是敏捷设计
查看>>
SCSS的基本操作
查看>>
"安装程序无法定位现有系统分区" 问题解决
查看>>
.NET中栈和堆的比较
查看>>
【莫队】bzoj 3781,bzoj 2038,bzoj 3289
查看>>
如何优化limit
查看>>
几种常用数据库字段类型查询语句
查看>>
字符全排列
查看>>
提高效率必须改掉的7种习惯
查看>>