数据五大类型
//1字符串型
var num2 ='2333fgfgfggggggggggggggggggggg';
//2数值型 num
var num1 = 1;
//3布尔型 boolean
var num3 =false;
//4对象型 object
var num4 = document.getElementById('mydiv');
//5未定义 undefined
6数组(Array)
7空值(Null)
数据类型检测方法
1,typeof
2,tostring
3,instanceof
4,constructor
5,在jQuery中
每种数据类型的内存分配
1,数值型
2,字符串
3,数组
4,函数
引用类型和值类型区别
内存分配机制不一样
引用类型—创建一个变量—内存中保存的是变量真实入口的地址
值类型:创建一个变量,内存创建一个区域
说白了就是引用类型会分配两个区域:一个保存地址,一个保存内容
变量赋值是否的区别
将一个值类型赋值给另一个变量,实际上新创建一个区域
引用类型,只是创建一个区域,保存另一个变量的入口地址
值类型赋值,会重新分配内存
引用类型赋值其实赋的是指针
值类型都是存放在栈内存空间的
引用类型都是存放在堆内存空间的
变量搜索机制
! 先局部变量,后全局变量。
语法规范
特性:我们一般将特性称之为属性
行为:称之为方法--其实就是一个函数
我们一般将属性放在上面,方法放在下面这个是固定用法
上面的这个容器叫构造函数,又叫构造对象,专门放置属性
下面的这种写法叫原型对象,专门放置方法
函数 对象 框架比较
函数:工具 封装细节 -- 不需要了解内部 只需要会用
封装复杂性:浏览器兼容性
对象:工具包 包含多个函数(工具
框架:多个工具包(对象)
面向对象的三个作用
1面向对象编程
2描述数据
3框架
xml操作
1、创建文档。
大家都知道,Xml是一种基于对象的语言,也就是说,在JavaScript中,很多东西也都是面向对象的。可以使用new关键字创建一个对象。当然,创建一个Xml文档也不例外。var xmlDoc = new ActiveXObject("Msxml2.DOMDocument.3.0");
2、添加节点。
其实,使用JavaScript操作Xml,和使用C#操作Xml有着几乎相同的方法。我们可以使用C#中一样的方法appendChild()方法来实现添加XML节点。说到这里你该问如何创建Xml节点了,其实还是跟C#相同的方法 var root = xmlDoc.createElement("root"); 将这个root节点添加到xmlDoc这个文档中就很简单了: xmlDoc.appendChild(root); 现在,xmlDoc中就有了一个根节点了。需要注意的是,一个Xml文档只能有一个根节点。其它的节点个数不限。
3、得到节点。
查询节点的方法就很多了。可以使用一个一个节点遍历,也可以使用selectSingleNode()方法或者selectNodes()方法。而得到一个文档根节点的方法则是通过属性documentElement来得到。那么得到xmlDoc的根节点就是 var rootNode = xmlDoc.documentElement;现在我们向root节点中添加一个book节点:var book = xmlDoc.createElement("book"); root.appendChild(bookNode); 那么得到book节点就是:var bookNode = root.selectSingleNode("book");或者var bookNode = root.selectNodes("book")[0]; 或者var bookNode = root.firstNode;你可以使用任何一种方法来得到自己想要的节点。
4、删除节点。
其实这个功能使用量是非常少的。你可以使用removeChild()方法来操作。这里不再详细说明。
Instanceof
用途:用于检测某个实例是有哪个构造函数创建出来的
用法举例:
console.log(iphone instanceof Product)//true
实例是如何在内存中存储的
任何变量都会占用内存
var num = 1
一切数据都是通过变量管理的
实例也是一个变量,他也是放在内存中的。
当我们实例化:其实就是将构造函数的属性拷贝一份,同时在内存中开辟一段新的区域保存这些值。
我们定义一个构造函数是不分配内存的,只有实例化的时候才分配内存
实例拷贝原理
每当我们实例化的时候,都会将构造函数的属性拷贝一份,同时赋给新值
因为有的构造函数有默认值
一旦你给实例赋给了新值,就会讲内存空间替换掉
为什么实例含有constructor属性
因为实例的属性都是拷贝自构造函数
会拷贝所有的构造函数中的属性,包含你定义的也包含系统隐藏的
而 constructor属性是构造函数中的一个隐藏属性
原型的属性(方法)共享理论
原型对象不管实例化多少次,都只会生成一次。。
实例化的时候只拷贝构造函数中的属性,而不会拷贝原型对象中的属性
函数和对象
其实js中本来没有对象这个概念
利用函数实现了对象
原型对象本质:
原型对象的属性和方法可以被所有实例共享
这样,如果我们需要修改所有实例中的属性或者方法,就只需要修改一处,就能够影响到所有实例了
设置属性的访问权限
Object.defineProperty(a,b,c);
介绍�a:须要属性设置的对象
�b:须要设置的属性名,(键值)�
c:是一个用于描述属性值得json数据.这个json数占领configurable,eumerable,writable,value构成�configurable:1.可否被删除,2.他的属性值可否被批改.3.可否把属性设置成接见器属性,默认是true,可以删除,,批改,设置
�eumerable:可否被for-in轮回到
�writable:默示属性值可否被批改
�value:属性值
公有属性和私有属性
双对象
双对象第一个对象:构造函数(对象)
- 构造函数对象
- 构造函数对象中的属性方法
- 构造属性 方法
双对象第二个对象:原型对象
- 原型
- 原型对象
- 原型属性 原型方法
属性访问搜索法则
首先遍历自己的属性(从构造函数拷贝过来的属性),如果找到就返回
如果没找到,就根据铁链寻找到原型对象,依次遍历原型对象中的属性,如果找到同名的属性就返回,就这么简单。
以上的链式访问形式有一个术语:原型链
实例属性和原型属性判断
hasOwnProperty() 方法
可以判定一个属性是存在于构造对象的实例上还是原型对象上。该 方法继承自 Object。
如果是实例对象—ture
如果是原型对象 – false