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) //
 
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
 

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

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

    1.Window对象是所有客户端JavaScript特性和API的主要接入点. Window对象中的一个重要属性是document,它引用Document对象. JavaScript程序可以通过Doc ...

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

    1.事件相关概念 事件类型:一个用来说明发生什么类型事件的字符串 事件目标:是发生的事件或与之相关的对象. 事件处理程序(事件监听程序):是处理货响应事件的函数. 事件对象:是与特定事件相关并且包含有 ...

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

    1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScri ...

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

    1.函数命名规范 函数命名通常以动词为前缀的词组.通常第一个字符小写.当包含多个单词时,一种约定是将单词以下划线分割,就像"like_Zqz()". 还有一种就是"lik ...

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

    javascript权威指南第6版学习笔记 javascript数组.函数是特殊对象 看一点少一点. 3.1.4 hello.js内容是 var x=.3-.2;var y=.2-.1 console ...

  6. JavaScript权威设计--JavaScript类型,值,变量(简要学习笔记三)

    1.负号是一元求反运算 如果直接给数字直接量前面添加负号可以得到他们的负值     2.JavaScript中的运算超出了最大能表示的值不会报错,会显示Infinity. 超出最小也不报错,会显示-I ...

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

    1.Window对象属性的文档元素(id) 如果在HTML文档中用id属性来为元素命名,并且如果Window对象没有此名字的属性,Window对象会赋予一个属性,它的名字是id属性的值,而他们的值指向 ...

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

    1.事件冒泡与事件捕获 2.事件与事件句柄   3.事件委托:利用事件的冒泡技术.子元素的事件最终会冒泡到父元素直到跟节点.事件监听会分析从子元素冒泡上来的事件. 事件委托的好处:     1.每个函 ...

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

    1.属性的特性 一个属性包含一个名字和4个特性.4个特性:值,可写性,可枚举性,可配置性   2.对象的三个属性 一:原型属性 要想检测一个对象是否是另一个对象的原型,使用isPrototypeOf( ...

随机推荐

  1. 【大型网站技术实践】初级篇:借助LVS+Keepalived实现负载均衡

    一.负载均衡:必不可少的基础手段 1.1 找更多的牛来拉车吧 当前大多数的互联网系统都使用了服务器集群技术,集群即将相同服务部署在多台服务器上构成一个集群整体对外提供服务,这些集群可以是Web应用服务 ...

  2. 前端制作动画的几种方式(css3,js)

    制作动态的网页是是前端工程师必备的技能,很好的实现动画能够极大的提高用户体验,增强交互效果,那么动画有多少实现方式,一直对此有选择恐惧症的我就总结一下,以便在开发的时候选择最好的实现方式. 1.css ...

  3. 【NLP】蓦然回首:谈谈学习模型的评估系列文章(一)

    统计角度窥视模型概念 作者:白宁超 2016年7月18日17:18:43 摘要:写本文的初衷源于基于HMM模型序列标注的一个实验,实验完成之后,迫切想知道采用的序列标注模型的好坏,有哪些指标可以度量. ...

  4. 在.NET Core之前,实现.Net跨平台之Mono+CentOS+Jexus初体验

    准备工作 本篇文章采用Mono+CentOS+Jexus的方式实现部署.Net的Web应用程序(实战,上线项目). 不懂Mono的请移步张善友大神的:国内 Mono 相关文章汇总 不懂Jexus为何物 ...

  5. [转载]强制不使用“兼容性视图”的HTML代码

    在IE8浏览器以后版本,都有一个"兼容性视图",让不少新技术无法使用.那么如何禁止浏览器自动选择"兼容性视图",强制IE以最高级别的可用模式显示内容呢?下面就介 ...

  6. css知多少之绝对定位小记

    一.position定位常见属性 对于属性position来说,属性值有static/relative/absolute/fixed/inherit以下只对绝对定位position:absolute详 ...

  7. Android 算法 关于递归和二分法的小算法

     // 1. 实现一个函数,在一个有序整型数组中二分查找出指定的值,找到则返回该值的位置,找不到返回 -1. package demo; public class Mytest { public st ...

  8. SQL Server常见问题介绍及快速解决建议

    前言 本文旨在帮助SQL Server数据库的使用人员了解常见的问题,及快速解决这些问题.这些问题是数据库的常规管理问题,对于很多对数据库没有深入了解的朋友提供一个大概的常见问题框架. 下面一些问题是 ...

  9. 树莓派3B的食用方法-1(装系统 网线ssh连接)

    首先要有一个树莓派3B , 在某宝买就行, 这东西基本上找到假货都难,另外国产和英国也没什么差别,差不多哪个便宜买哪个就行. 不要买店家的套餐,一个是配的东西有些不需要,有的质量也不好. 提示:除了G ...

  10. 周末聊聊IT人员的人脉观:关于帮妹子找兼职有感

    背景: 前几天,有个认识了好几年的网友,现在是大学生,在厦门读大一,说和她同学要一起到广州找兼职,看我有没有介绍. 像我这么积极热心善良的人,就说帮她找找看,结果问了几次,没消息,只好诚实的回复人家, ...