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
 
转载:http://www.cnblogs.com/zqzjs/p/4805350.html
目录
相关文章
|
8天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
18天前
|
JavaScript 前端开发
Math对象:JavaScript中的数学工具
Math对象:JavaScript中的数学工具
26 1
|
11天前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
3天前
|
JavaScript
【Js】检查Date对象是否为Invalid Date
【Js】检查Date对象是否为Invalid Date
6 0
|
3天前
|
存储 JavaScript 前端开发
JavaScript的引用数据类型主要包括对象
【4月更文挑战第16天】JavaScript的引用数据类型主要包括对象
16 4
|
8天前
|
JavaScript
js 字符串String转对象Object
该代码示例展示了如何将一个以逗号分隔的字符串(`&#39;1.2,2,3,4,5&#39;`)转换为对象数组。通过使用`split(&#39;,&#39;)`分割字符串并`map(parseFloat)`处理每个元素,将字符串转换成浮点数数组,最终得到一个对象数组,其类型为`object`。
|
16天前
|
存储 JavaScript 前端开发
在浏览器中存储数组和对象(js的问题)
在浏览器中存储数组和对象(js的问题)
|
移动开发 JavaScript 前端开发
《JavaScript设计与开发新思维》——2.2 HTML5入门
从第一行开始,我们已经说过,简单的HTML5 DOCTYPE将使浏览器处于标准模式,这是我们的第一个目标。接下来是一个html元素,其中包含head和body元素。奇怪的是,HTML5不需要head元素,但是不使用它我感觉不安。
1652 0
|
Web App开发 移动开发 前端开发
《JavaScript设计与开发新思维》——导读
JavaScript是当今使用最广泛的编程语言之一,可以在几乎所有网页(在所有新的网页)上找到。过去的10年,在经济变化和JavaScript使用方式的扩展之间,越来越多的Web开发人员和设计人员希望了解这种语言。
1543 0
|
移动开发 JavaScript 前端开发
《JavaScript设计与开发新思维》——2.7 小结
本章的主要部分使用现实世界中的代码,介绍了一个具体的例子:验证提交的登录表单。你学习了事件处理、创建自定义函数以及通过document.getElementById()引用页面元素的基础知识。如果在后续章节中学习新知识时对这些基础元素感到混淆,可以回过头来看看这个例子。
1304 0