JavaScript权威设计--JavaScript对象(简要学习笔记七)

1.with语句

语法:

width(object){
    statement
}

with语句可用于临时扩展作用域链。作用域链可以按序检索的对象列表,通过它可以进行变量名解析。

with将object添加到作用域链的头部,然后执行内部statement,最后把作用域链回复到原始状态。

但是:with语句要尽量避免使用。有with代码的语句难以优化,且运行的更慢。

在对象嵌套跟多层次的时候通常会使用with来优化。

如:

document.forms[0].address.value
//->
with(document.forms[0]){
    //直接访问表单元素
    name.value="";
    ....
}

这样写的话就不用再为每个属性添加document.forms[0]前缀。这个对象临时挂载在作用域链上。

同样也可以这么写:

var f=document.forms[0];
f.name.value="";

需要注意的是:只有在查找标识符的时候才会用到作用域链,创建新变量的时候不使用。

如:

with(0){
    x=1;
}
//->x=1

2.创建对象

可通过对象直接量,关键字,new 和Object.create()函数来创建对象

方式一:对象直接量创建对象

如:

var emp={
    x:0,
    y:0
}

对象直接量是一个表达式,该表达式的每次运算都创建并初始化一个新的对象。

方式二:new创建对象

new后面跟一个函数调用,这里的函数称作构造函数,构造函数友谊初始化一个新创建的对象。

如:

var o=new Object();    //创建一个空对象,和var o={}一样

方式三:Object.create()函数来创建对象

通过new Date()创建的对象的原型是Date.prototype

Date.prototype的属性继承自Object.prototype

所以通过new Date()创建的Date()对象的属性同事继承自Date.prototype和Object.prototype,

这一系列链接的原型对象就是所谓的"原型链"。

如:

var plo=Object.create({ x:1, y:2});    //plo继承了属性x和y
var plo=Object.create(null);    //创建了一个没有原型的新对象,plo不继承任何属性和方法,也就是说他不能与"+"运算符一起正常工作
var plo=Object.create(Object.prototype);    //创建一个空对象,和{}一样

3.作为关联数组的对象

object.prot    //使用点运算符,与C和Java有点类似

object["prot"]    //使用方括号和一个字符串,看起来更像数组,不过这里使用的是字符串索引,这种数组就是关联数组,或称作散列,映射或字典

当通过[]来访问对象的属性时,属性名用过字符串来表示。字符串是JavaScript的数据类型,在程序运行时可以修改和创建他们。

如:

var addr="";
for(var i=0;i<4;i++){
    addr+=customer["address"+i]+‘\n‘
}

这段代码读取customer独享的address0,...address3的属性。

4.简单继承

假设要查询对象o的属性x,如果o中不存在x,那么将会继续在o的原型对象中查询该属性x。

如果原型对象中也没有x,但是这个原型对象也有原型,那么继续在这个原型对象的原型对象中进行查询,指导找到

x或查找到一个原型是null的对象为止。可以看到,对象的原型属性构成了一个"链",通过这个"链"可以实现属性的继承。

var o={}    //o继承自Object.prototype
o.x=1;
var p=o    //p继承自o和Object.prototype
p.x=2;
alert(o.x)    //2

5.检测属性

方法一:in(in可以区分不存在的属性和存在但是值为undefined的属性)

var o={
    x:1
}
"x"    in o    //true
"y"    in o    //false
"toString"    in o    //true:o继承toString属性
delete o.x
"x"    in o    //false:属性不在存在

方法二:hasOwnProperty() 用来检测给定的名字是否是对象的自由属性。是的话返回true,如果是继承的属性返回false。

var o={
    x:1
}
o.hasOwnProperty("x")    //true
o.hasOwnProperty("y")    //false
o.hasOwnProperty("toString")    //false

方法三:!==(该运算符可以区分undefined和null,而"!=则不能")

var o={
    x:1
}
o.x!==1;    //false
时间: 2024-10-06 00:45:07

JavaScript权威设计--JavaScript对象(简要学习笔记七)的相关文章

JavaScript权威设计--Window对象(简要学习笔记十三)

1.Window对象是所有客户端JavaScript特性和API的主要接入点. Window对象中的一个重要属性是document,它引用Document对象. JavaScript程序可以通过Document对象和它包含的Element对象遍历和管理文档. 2.URL中的JavaScript 在URL后面跟一个JavaScript:协议限定符.里面的代码会作为JavaScript代码进行运行,需用分号分割. 如: <a href="javascript:alert('OK!')"

JavaScript权威设计--事件处理介绍(简要学习笔记十七)

1.事件相关概念 事件类型:一个用来说明发生什么类型事件的字符串 事件目标:是发生的事件或与之相关的对象. 事件处理程序(事件监听程序):是处理货响应事件的函数. 事件对象:是与特定事件相关并且包含有关该事件详细信息的对象. 事件传播:是浏览器决定哪个对象触发其事件处理程序的过程. 事件捕获:在容器元素上注册的特定处理程序有机会再事件传播打破真实目标之前拦截它. 阻止标签默认事件的发生 2.Window事件 focus,blur不冒泡.focusin,focusout冒泡. load当文档和其他

JavaScript权威设计--JavaScript函数(简要学习笔记十)

1.函数命名规范 函数命名通常以动词为前缀的词组.通常第一个字符小写.当包含多个单词时,一种约定是将单词以下划线分割,就像"like_Zqz()". 还有一种就是"likeZqz()".有些些函数是用作内部用的或者为私有函数通常以一条下划线为前缀,就像"_zqzName()". 2.以表达式方式定义的函数 如: var zqz=function (){ return "zhaoqize"; } 在使用的时候必须把它赋值给一个变

javascript权威指南第6版学习笔记

javascript权威指南第6版学习笔记 javascript数组.函数是特殊对象 看一点少一点. 3.1.4 hello.js内容是 var x=.3-.2;var y=.2-.1 console.log(x==y);console.log(x==.1);console.log(y==.1); 控制台输出结果: 3.1.5 var now = new Date();console.log(now); 3.2 文本 Javascript没有字符型,只有字符串. 16位怎么理解 3.10 变量作

JavaScript权威设计--Window对象之Iframe(简要学习笔记十四)

1.Window对象属性的文档元素(id) 如果在HTML文档中用id属性来为元素命名,并且如果Window对象没有此名字的属性,Window对象会赋予一个属性,它的名字是id属性的值,而他们的值指向表示文档元素的HTMLElement对象. Window对象是以全局对象的形式存在于作用域链的最上层,这就意味着HTML文档中使用的id属性会成为可以被脚本访问的全局变量. 如: <button id="but"/> 就可以通过全局变量but来引用此元素. 2.多窗体窗口(if

JavaScript权威设计--JavaScript对象(简要学习笔记八)

1.属性的特性 一个属性包含一个名字和4个特性.4个特性:值,可写性,可枚举性,可配置性 2.对象的三个属性 一:原型属性 要想检测一个对象是否是另一个对象的原型,使用isPrototypeOf()方法 如: var P={x=1}; //定义一个原型对象 var o=Object.create(p); //使用这个原型对象创建一个对象 p.isPrototypeOf(o) //true:o继承自p Object.isPrototypeOf(p) //true:p继承自Object.protot

JavaScript权威设计--事件冒泡,捕获,事件句柄,事件源,事件对象(简要学习笔记十八)

1.事件冒泡与事件捕获 2.事件与事件句柄 3.事件委托:利用事件的冒泡技术.子元素的事件最终会冒泡到父元素直到跟节点.事件监听会分析从子元素冒泡上来的事件. 事件委托的好处: 1.每个函数都是对象,都会占用内存,内存中对象越多,性能越差. 2.必须事先指定所有事件处理程序而导致的DOM访问次数,会延迟整个页面的交互就绪时间. 怎样处理由于事件较多引起的性能差: 1.采用事件委托技术,限制简历的连接数量 2.在不需要的时候移除事件处理程序 例子: html: <div id="myDiv&

JavaScript权威设计--JavaScript函数(简要学习笔记十一)

1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScript构造函数调用的语法是允许省略实参列表和圆括号的. 如: var o=new Object(); //->等价于 var o=new Object; 第四种:使用call()与apply()间接调用(放在后面详细说明) 2.函数的实参与形参——可选形参 先看一个例子: function getA(

JavaScript权威设计--JavaScript数组(简要学习笔记九)

1.数组的创建 如: var a=[1.1,null,"a"]; var b=[1, ,3]; //中间的那个元素是undefined var c=[ , , ] 这里c.length你是不是以为是3? 哈哈,长度应该是2.因为数组直接量的语法允许有可选的结尾逗号. 2.数组索引的其他种类 a[-1.23]=true    //创建一个名为-1.23的属性 a["1000"]=0    //如果是字符串,它就转换为数组的索引 a[1.000]    //和a[1]相