for/in 语句循环遍历对象的属性。 
js中获取key得到某对象中相对应的value的方法:obj.key 
js中根据动态key得到某对象中相对应的value的方法有二: 
一、var key = "name1";var value = obj[key]; 
二、var key = "name1";var value = eval("obj."+key);

object对象没有length属性,那么获取object对象的length就可以通过遍历得到key值的数组的长度来获取啦~

使用 for in 循环遍历对象的属性时,原型链上的所有属性都将被访问:

  1. Object.prototype.bar = 10;// 修改Object.prototype
  2. var obj={"name":"wjy","age":26,"sex":"female"};//定义一个object对象
  3. var keys=[];//定义一个数组用来接受key
  4. var values=[];//定义一个数组用来接受value
  5. for(var key in obj){
  6. keys.push(key);
  7. values.push(obj[key]);//取得value
  8. }
  9. alert("keys is :"+keys+" and values is :"+values);
  10. //keys is : name,age,sex,bar and values is : wjy,26,female,10

  推荐总是使用 hasOwnProperty 方法, 这将会避免原型对象扩展带来的干扰:

  1. function allpro(obj){
  2. var keys=[];
  3. var values=[];
  4. for(var key in obj){
  5. //只遍历对象自身的属性,而不包含继承于原型链上的属性。
  6. if (obj.hasOwnProperty(key) === true){
  7. keys.push(key);
  8. values.push(obj[key]);
  9. }
  10. }
  11. alert("keys is :"+keys+" and values is :"+values);
  12. }
  13. Object.prototype.bar = 1;// 修改Object.prototype
  14. var o={"name":"wjy","age":26,"sex":"female"};//定义一个object对象
  15. allpro(o);
  16. //keys is : name,age,sex and values is: wjy,26,female

  

1.遍历可枚举的自身属性

可枚举的意思就是该属性的[[Enumerable]]特性为true,自身属性的意思就是该属性不是从原型链上继承下来的.

  1. (function () {
  2. var propertys = Object.keys(window);
  3. alert(propertys.length); //3
  4. alert(propertys.join("\n")); //window,document,InstallTrigger,除了最后一个是火狐私有的属性,原来window对象只有两个可枚举的自身属性.window属性指向window对象自身,一般没什么用.
  5. })()

  

2.遍历所有的自身属性

特性为不可枚举的属性也并不是遍历不到,ES5给我们提供了getOwnPropertyNames方法,可以获取到一个对象的所有自身属性.

  1. (function () {
  2. var propertys = Object.getOwnPropertyNames(window);
  3. alert(propertys.length); //72
  4. alert(propertys.join("\n")); //Object,Function,eval等等
  5. })()

  

3.遍历可枚举的自身属性和继承属性

继承属性怎么遍历,你应该知道,就是最常用的for in遍历

  1. (function () {
  2. var getEnumPropertyNames = function (obj) {
  3. var props = [];
  4. for (prop in obj) {
  5. props.push(prop);
  6. }
  7. return props;
  8. }
  9. var propertys = getEnumPropertyNames(window);
  10. alert(propertys.length); //185
  11. alert(propertys.join("\n")); //addEventListener,onload等等
  12. })()

  

4.遍历所有的自身属性和继承属性

这种遍历主要用在各种js调试工具的代码补全功能上.比如Firebug的.

  1. (function () {
  2. var getAllPropertyNames = function (obj) {
  3. var props = [];
  4. do {
  5. props = props.concat(Object.getOwnPropertyNames(obj));
  6. } while (obj = Object.getPrototypeOf(obj));
  7. return props;
  8. }
  9. var propertys = getAllPropertyNames(window);
  10. alert(propertys.length); //276
  11. alert(propertys.join("\n")); //toString等
  12. })()

  

JavaScript中对象的属性:如何遍历属性的更多相关文章

  1. JavaScript中对象的属性

    在JavaScript中,属性决定了一个对象的状态,本文详细的研究了它们是如何工作的. 属性类型 JavaScript中有三种不同类型的属性:命名数据属性(named data properties) ...

  2. javascript中元素的scrollLeft和scrollTop属性说明

    再说意义之前,前说一下这两个属性的适用范围: 注意:这两个属性只能用于元素设置了overflow的css样式中.否者这两个属性没有任何意义.且overflow的值不能为visible,但可以为hidd ...

  3. javascript中对象字面量的理解

    javascript中对象字面量与数组字面量 第一部分 我们知道JavaScript中的数据类型有基本数据类型和引用类型,其中Object类型就是非常常用的类型.那么如果创建一个Object类型的实例 ...

  4. JavaScript 中的12种循环遍历方法

    原文:JavaScript 中的12种循环遍历方法 题目:请介绍 JavaScript 中有哪些循环和遍历的方法,说说它们的应用场景和优缺点? 1.for 循环 let arr = [1,2,3];f ...

  5. 关于JavaScript中对象的继承实现的学习总结

    一.原型链 JavaScript 中原型链是实现继承的主要方法.其主要的思想是利用原型让一个引用类型继承另一个引用类型的属性和方法.实现原型链有一种基本模式,其代码如下. function Super ...

  6. javascript中对象的深度克隆

    记录一个常见的面试题,javascript中对象的深度克隆,转载自:http://www.2cto.com/kf/201409/332955.html 今天就聊一下一个常见的笔试.面试题,js中对象的 ...

  7. 【你不知道的javaScript 上卷 笔记7】javaScript中对象的[[Prototype]]机制

    [[Prototype]]机制 [[Prototype]]是对象内部的隐试属性,指向一个内部的链接,这个链接的作用是:如果在对象上没有找到需要的属性或者方法引用,引擎就 会继续在 [[Prototyp ...

  8. JavaScript中对象转换为原始值的规则

    JavaScript中对象转换为原始值遵循哪些原则? P52 对象到布尔值对象到布尔值的转换非常简单:所有的对象(包括数字和函数)都转换为true.对于包装对象亦是如此:new Boolean(fal ...

  9. [转] JavaScript中的属性:如何遍历属性

    在JavaScript中,遍历一个对象的属性往往没有在其他语言中遍历一个哈希(有些语言称为字典)的键那么简单.这主要有两个方面的原因:一个是,JavaScript中的对象通常都处在某个原型链中,它会从 ...

随机推荐

  1. LeetCode: 620 Not Boring Movies(easy)

    题目: X city opened a new cinema, many people would like to go to this cinema. The cinema also gives o ...

  2. Axure RP 7.0 标准教程(2)--基本介绍

    母版:用来放置一些相同元素的部件  两个页面都放入母版   一处更改 所有更改 添加图片:双击可以本地添加 ---------- 创建share.axure账号  https://share.axur ...

  3. C++设计模式之工厂方法模式

    来自:http://blog.csdn.net/pangshaohua/article/details/38912555 参考写的一个工厂demo 1.定义"背景风格的抽象类".& ...

  4. 【Linux】Devops的一些运维工具

    一.Devops简介 从手工编译.上传服务器文件.执行命令.启动停止服务器.发现BUG再重复一遍流程,软件开发的重复劳动越来越多,在Devops概念之前,全部要靠人工手动完成,也看到了很多运维人员半夜 ...

  5. python自建模块显示说明与详情

    通常我们自建模块放在/usr/lib/python2.7/site-packages下面,这样可以python就可以进行调用. 但是,自建模块也要有详细的说明情况,例如查help,可以看出来模块的作用 ...

  6. 几例实用的Shell脚本

    日常工作中,经常编写一些shell命令或脚本以完成重复性操作,本文分享了最近用到的几例shell实用脚本. 1 特殊文件名的远程拷贝 服务器之间拷贝文件经常使用scp命令,其命令格式: (1)scp ...

  7. B. Lecture Sleep( Educational Codeforces Round 41 (Rated for Div. 2))

    前缀后缀和搞一搞,然后枚举一下区间,找出最大值 #include <iostream> #include <algorithm> using namespace std; ; ...

  8. scrapy框架的命令行解释

    scrapy框架的命令解释 创建爬虫项目 scrapy startproject 项目名例子如下: scrapy startproject test1 这个时候爬虫的目录结构就已经创建完成了,目录结构 ...

  9. UVA10129:Play on Words(欧拉回路)

    Some of the secret doors contain a very interesting word puzzle. The team of archaeologists has to s ...

  10. 在 Linux 环境直接复移动硬盘上的 GRUB

    手头有一块用了 10 年的旧移动硬盘,其中安装了 Debian 系统,从低版本一直升级到现在的 9 已经用了很长时间.前不久正连着那块硬盘跑着 Debian 修改文件的时候,由于一个本可避免的意外震动 ...