js笔记8
1.js数据类型
基本数据类型:string、undefined、null、boolean、nember
引用数据类型:object、array、function
二者的区别?
基本的数据类型就是简单的赋值,引用数据类型,把引用的地址赋值给变量
2.堆内存
就是存放代码的,存放形式有两种,一种是对象以键值对的形式存放
另一种就是函数,以字符串的形式存放
案例(1)
引用数据类型的赋值,是把引用地址赋给它,在修改属性的时候,通过地址查找然后改掉
案例(2)
应用数据类型,如何操作?
先通过引用地址去查找堆内存中的代码,然后再去修改
3.this 研究在函数内部
在js中的函数形式的种类
1.普通函数 function fn() var fn=function()
2.类
4.对象object
对象里面的数据以键值对的形式存在。跟json一样
(1)单例模式==》对象
我们把变量zhang和li叫“命名空间”
作用域和堆内存的区别?
作用域是函数执行的时候产生fn()
函数执行的时候首先会开辟一个新的内存空间叫栈内存(环境或作用域)
数据类型在赋值的时候会开辟一个新的内存空间叫堆内存(存放代码块的)
二者都会形成一个内存地址
生成对象的单例模式
优势,每个对象都是独立的,即便属性起的名字一样,不会互相干扰,方便现在流行的开发模式“模块化开发”。如果需要使用里面的属性,用.运算符 如zhang.name或zhang["name"]判断一个属性是不是这个对象的用in运算符 如“name”in zhang 如果遍历这个对象用 for(attr in zhang){}
缺点,不能批量生产,只能一个一个的去创建
(2)工厂模式==》对象
这种形式我们叫做函数封装。优势,可以批量生产,减少冗余的代码,提高代码重复利用率(高密度低耦合)。没有继承和多太
(3)构造函数==》对象
要求:a。函数名首字母必须大写 b。里面的属性前面必须加this c。函数调用的时候必须使用new关键字
我们把Person叫类,把zhang叫实例。万物皆对象。对象的特征有属性和方法
构造函数里的this指向实例对象
构造函数里有了类和实例的概念,并且实例和实例都是独立的个体,我们把他叫做实例识别
构造函数里面的属性都是私有的,各个实例对象之间没有公共的属性
为了实例的对象拥有公共的属性,所以js使用了prototype(原型)这个属性,属性值是一个对象,我们可以把公共的属性放在这个prototype上了
5.原型分析
(1)每个函数数据类型(普通函数,类)都有一个prototype属性,并且这个属性是对一个对象数据类型
(2)每一个prototype上都有一个constructor属性,并且这个属性值是当前函数或类本身
(3)每一个对象数据类型(实例,普通对象,prototype)都天生具有一个__proto__属性,他的属性值是当前实例所属类的原型
通过图像我们知道 zhang.__proto__==Person.prototype true
6.原型链
Duixiang.shuxing的时候,首先看这个属性是不是私有的,私有的就直接使用,如果私有的属性没有,就找共有的,公有的有就使用,没有就按照__proto__找他的类上有没有,直到找到基类Object。如果Object没有就undefined了,这种查找机制叫原型链
7.数据的三种存储类型
(1)String ""
(2)Array []
(3)Json {}
8.所有的编程语言 java c c++ python 等,他们都是面向对象的编程,面向对象必须有三大特点,封装,继承,多太
js笔记8的更多相关文章
- Data Visualization and D3.js 笔记(1)
课程地址: https://classroom.udacity.com/courses/ud507 什么是数据可视化? 高效传达一个故事/概念,探索数据的pattern 通过颜色.尺寸.形式在视觉上表 ...
- js笔记-0
#js笔记-0 数组: indexOf方法: Array也可以通过indexOf()来搜索一个指定的元素的位置: var arr = [10, 20, '30', 'xyz']; arr.indexO ...
- PPK谈JS笔记第一弹
以下内容是读书笔记,再一次温习JS好书:PPK谈JS window.load=initializePageaddEventSimple('window','load',function(){}) lo ...
- 面向小白的JS笔记 - #Codecademy#学习笔记
前言 最初浏览过<JavaScript秘密花园>,前一段时间读过一点点<JavaScript语言精粹>和一点点<JavaScript高级程序设计>(一点点是指都只是 ...
- require.js笔记
笔记参考来源:阮一峰 http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 1. 浏览器端的模块只能采用“异步加载”方式 = ...
- JS笔记 入门第四
小测试: 注意:取消所有的设定可以直接使用 document.getElementById("txt").removeAttribute("style"); 这 ...
- JS笔记 入门第二
输出内容 document.write(); alert("hello!"); alert(mynum); </script> 注:alert弹出消息对话框(包含一个确 ...
- Node.js笔记1
Node.js入门笔记 1. node -help 可以显示帮助信息2. node REPL 模式(Read-eval-print loop) 输入—求值—输出循环 直接在cmd输入node 可以进入 ...
- JS笔记 入门第一
WHY? 一.你知道,为什么JavaScript非常值得我们学习吗? 1. 所有主流浏览器都支持JavaScript. 2. 目前,全世界大部分网页都使用JavaScript. 3. 它可以让网页呈现 ...
- 奇舞js笔记——第0课——如何写好原生js代码
摘要 1.好的代码职责要清晰,javscript不要用来操作样式: 2.API要设计的合理:通用性,适度的抽象(数据抽象,过程抽象),可扩展性: 3.效率问题:用好的.合适的算法(前端程序员要把自己当 ...
随机推荐
- 关于文字内容过长,导致文本内容超出html 标签宽度的解决方法之自动换行
在标签的style 属性中设置 word-break style="word-break:break-all;" 这样就可以实现换行 上截图没设置之前 设置之后 完美解决!!!!! ...
- [bug] redis-cli连接时出现Could not connect to Redis at 127.0.0.1:6379: Connection refused
参考 https://www.geek-share.com/detail/2684728161.html
- 用JIRA管理你的项目——(一)JIRA环境搭建
JIRA,大家应该都已经不陌生了! 最初接触这个工具的时候,我还在一味地单纯依靠SVN管理代码,幻想着SVN可以有个邮件通知,至少在项目成员进行代码修改的时候,我可以第一时间通过邮件获得这个消息! 当 ...
- VulnHub系列(一)DC-1
环境 kali linux 和 DC-1 都是搭建在VMware上的虚拟机,都是NAT模式. 主机发现 NAT模式下虚拟机没有被分配真实的ip地址,他们通过共享宿主机的ip地址访问互联网.我们可以通过 ...
- nginx官方源安装-主配置文件详解
HTTP相关术语 PV : Page Visit 页面独立浏览量,查看日志生成条数可以看到PV数量. PV全称Page View,中文翻译即页面浏览.其具体的度量方法是从浏览器发出一个对网络服务器的请 ...
- Java 四种内置线程池
引言 我们之前使用线程的时候都是使用 new Thread 来进行线程的创建,但是这样会有一些问题 每次 new Thread 新建对象性能差 线程缺乏统一管理,可能无限制新建线程,相互之间竞争,及可 ...
- python基础之迭代器、生成器、装饰器
一.列表生成式 a = [0,1,2,3,4,5,6,7,8,9] b = [] for i in a: b.append(i+1) print(b) a = b print(a) --------- ...
- 抓住异步编程async/await语法糖的牛鼻子: SynchronizationContext
长话短说,本文带大家抓住异步编程async/await语法糖的牛鼻子: SynchronizationContext 引言 C#异步编程语法糖async/await,使开发者很容易就能编写异步代码. ...
- UEFI和Legacy兼容启动U盘制作
应用场景 自己有一个可启动移动硬盘,是属于老式的BIOS启动方式,最近换了新电脑,因为电脑只支持uefi的启动方式,所以决心为移动硬盘增加uefi启动支持,如何将一个只支持BIOS启动(或者 Lega ...
- node.js学习(5)读写文件(同步异步)
1 导入文件系统库 # 同步的 读文件 写文件 # 异步 需要用异步处理耗时