JavaScript权威设计--JavaScript对象(简要学习笔记七)-阿里云开发者社区

开发者社区> shy丶gril> 正文

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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
JavaScript之对象拷贝与赋值
今天在做公司面试题的时候,遇到了一道关于JavaScript之对象拷贝与赋值的问题,突然觉得很有意义,想和大家一起来分享一下! 首先,先摆出代码,如下: /** * Created by Administrator on 2016/12/7.
657 0
Java编程基础阶段笔记 day 07 面向对象编程(上)
面向对象编程笔记Notes:面向对象三条学习主线、面向过程 VS 面向对象、类和对象、创建对象例子、面向对象的内存分析
577 0
学习记录ES6反射内置对象Proxy与Reflect
工作中遇见了一个这样的需求:网页预览视频文件(格式有两种mp4与wmv)时,mp4格式的采用浏览器自带的video标签进行播放,wmv格式的由于浏览器不支持直接播放,则需要调用定制的wmvH5播放器来播放。 经调研发现wmvH5播放器实际上也是采用video标签进行播放的,只不过是加载、播放、暂停、定位播放等核心功能进行了特殊定制,其他如音量控制、播放状态等都是video自带的。 为了
1424 0
JavaScript面向对象的编程指南学习笔记
JavaScript面向对象的编程指南学习笔记 第一章 1,用自己的语言描述出,什么是对象、类、封装、聚合、继承、多态? 对象,拥有属性和方法的任何抽象概念。 类,可以实例化,有共同属性或方法(行为)的相似对象,的模板 封装,提供接口,隐藏接口的实现 聚合,将大功能(对象)拆分成小功能(小对象)去实现的逆过程。
8816 0
《JavaScript启示录》——第1章 JavaScript对象 1.1创建对象
JavaScript实际上是一种预包装若干原生对象构造函数的语言。这些构造函数用于生成一些表达特定类型值(如数字、字符串、函数、对象、数组等)的复杂对象,同样,也可以通过Function()对象创建自定义的对象构造函数(例如Person())。
1310 0
《JavaScript高级程序设计(第3版)》阅读笔记
第6章 面向对象的程序设计 6.2 创建对象 6.2.1 工厂模式 JavaScript创建对象(一)—— 工厂模式 6.
828 0
类与对象 - PHP手册笔记
原文:类与对象 - PHP手册笔记 基本概念 PHP对待对象的方式与引用和句柄相同,即每个变量都持有对象的引用,而不是整个对象的拷贝。 当创建新对象时,该对象总是被赋值,除非该对象定义了构造函数并且在出错时抛出了一个异常。
764 0
+关注
1878
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载