1.   定义:对象是JS的核心概念,也是最重要的数据类型。js的所有数据都可以被视为对象。
                对象是一种无序的数据集合,由若干个键值对(key:value)构成,由{ }包裹;
 
2.写法:var  obj={  
                    属性名:属性值,
                    属性名:属性值,
                    属性名:属性值        最后一个键值不建议添加逗号(ie8不兼容);
                     };
 
            A、对象的所有键名都是字符串,所以在书写时加不加引号都可以。
            B、键名又称“属性”(property),它的键值可以是任何数据类型。
            C、如果一个属性的值为函数,通常把这个属称成为“方法”,它可以像函数那样调用。
 
注意:(1)键名要符合标识符命名规范;
           (2)如果不符合要加“  ”;
           (3)键名可以是数值,它会自动被转换为字符串;
           (4)键名可以是js的关键字(保留字),但不推荐使用;
 
3.创建object的方法:
    (1)字面量方法定义:var obj={ };
    (2)构造函数创建:var  obj=new Object( ) ;
    (3)基于原型(继承方式):  var obj=Object.Creat( null ) ; (不常用)    
 
4.读写属性
 
    (1)读取属性:A、 点运算符------对象名 .  属性名;
                               B、 方括号输出-------对象名[ '属性名' ]  ;
            注意:(1)数字键名不可以用点运算符来读取(因为会被当做小数点),
                       (2)数字键只能使用方括号运算符读取,可以不加引号(因为会自动被转换为字符串处理)。
                       (3)方括号里的属性名一定要加引号(数字键随意);
 
    (2)写入属性(赋值):    A、点属性写入        obj.属性名=属性值;
            (无序)                    B、[    ]形式写入        obj[  '属性名' ]=属性值  ;
             js允许属性的‘属性的后绑定’,可以动态创建;
 
5.查看所有的属性: Object . keys(obj)    返回值为对象中全部的属性名,结果是属性名组成的数组集合;
 
6.删除属性:        delete  obj . 属性名        删除成功返回值为true,否则返回false;
                            删除后再去查看该属性,返回值为undefined;
                            删除一个不存在的属性,不会报错,返回值为true;
                            delete命令只能删除对象本身的属性。可以用hasOwnProperty来判断一下是否是对象本身的属性。
 
7.对象引用:  不同变量名指向同一个对象(引用同一个对象),修改其中一个变量,会影响到其它所有的变量;
var  o1 = {},
o2 = {name:123}
o1 = o2;
o1.name; // 123
o2.name = 456;
o1.name; // 456
8.in 运算符:用于检测对象是否包含某个属性(键名);
             属性名 in obj  ("name" in p) 包含返回值为true,否则返回false;
 
9.for…in (无序的):遍历一个对象的所有属性,返回----属性值;
for( var i in p){
    console.log(p[i]);
};



10.with :操作同一个对象的多个属性,减少代码量,避免重复书写(写法类似于while);
   with(object){
      属性名=属性值;    with语句块,所有赋值后的语句后面要加分号;

     name = 1000;
age = 3;

    }
     注意:(1)查看object.name ,返回值为undefined;
           (2)with区块对name操作,等于创建了一个全局变量name,该属性不属于对象
;可以先定义object的属性name,然后在with区块内操作它;
           (3)可以为对象的属性进行再赋值,覆盖掉原来的属性值;
 
<-----------学习笔记,谢谢指正!----------->

JavaScript-Object基础知识的更多相关文章

  1. 快速掌握JavaScript面试基础知识(三)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  2. 快速掌握JavaScript面试基础知识(二)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  3. javascript的基础知识及面向对象和原型属性

    自己总结一下javascript的基础知识,希望对大家有用,也希望大家来拍砖,毕竟是个人的理解啊 1.1 类型检查:typeof(验证数据类型是:string) var num = 123; cons ...

  4. JavaScript 之基础知识

    JavaScript 基础知识 JavaScript 是属于网络的脚本语言! JavaScript 被数百万计的网页用来改进设计.验证表单.检测浏览器.创建cookies,以及更多的应用. JavaS ...

  5. JavaScript对象基础知识总结

    1.什么叫JavaScript对象? 定义:名值对的集合.简单的讲就是容纳属性值和属性值的容器,这些属性可以是无序的,基本上JavaScript中所有的事物都可以看成对象. 拓展:我们经常说,数组也是 ...

  6. JavaScript笔记——基础知识(一)

    <Script>标签属性 <script>xxx</script>这组标签,是用于在 html 页面中插入 js 的主要方法.它主要有以下 几个属性: charse ...

  7. javascript 正则表达式基础知识汇总

    正则表达式:对字符串中的信息实现查找.替换和提取操作.(不支持注释和空白,必须写在一行内)正则表达式的创建:包含在一对斜杠之间的字符(直接量语法)例如:var pattern = /s$/;     ...

  8. JavaScript语言基础知识8

    这篇文章是对前面学习的知识进行总结: 1.JavaScript支持多种数据类型,如数值类型.字符串类型.布尔类型等. 2.在JavaScript中,字符串是用引號括起来的字符系列,转义字符能够用来表示 ...

  9. javascript的基础知识整理

    Basic ObjectsArray Properties constructor  属性返回对创建此对象的数组函数的引用 object.constructor prototype 属性使您有能力向对 ...

  10. JavaScript笔记——基础知识(二)

    Function类型 函数function不需要返回类型(不是没有返回值),参数也不需要指定类型,更为特殊的是函数竟然是个类,可以通过new出来 var box= new Function('num1 ...

随机推荐

  1. Linux远程执行Shell命令或脚本

    ## 远程执行shell命令 ssh [user]@[server] '[command]' # eg. ssh root@192.168.1.1 'uptime' ## 远程执行本地shell脚本 ...

  2. MySQL · 答疑解惑 · MySQL 锁问题最佳实践

    http://mysql.taobao.org/monthly/2016/03/10/ 前言 最近一段时间处理了较多锁的问题,包括锁等待导致业务连接堆积或超时,死锁导致业务失败等,这类问题对业务可能会 ...

  3. 在一个aspx或ashx页面里进行多次ajax调用

    在用ajax开发asp.net程序里.利用ashx页面与前台页面进行数据交互.但是每个ajax交互都需要一个ashx页面.结果是项目里一大堆ashx页面.使项目难以管理.现在我们就想办法让一个ashx ...

  4. java类加载器及其委托机制

    1.什么是类加载器,类加载器父子结构.BootStrap-->ExtClassLoader-->AppClassLoader,级别依次降低 2.类加载器之间的父子关系和管辖范围 3.类加载 ...

  5. Android studio 英文——中文 翻译插件

    TranslationPlugin 1.手动下载 TranslationPlugin ,在Android studio 中 2. 3. 4.选中文件,点击OK 5.设置快捷键 代号1 : 代号2 :

  6. context:component-scan标签的use-default-filters属性的作用以及原理分析

    一.背景 我们在Spring+SpringMVC+Mybatis的集成开发中,经常会遇到事务配置不起作用等问题,那么本文就来分析下出现这种问题可能的原因以及解决方式. 二.分析及原理窥探 1.项目结构 ...

  7. 解决ftp上传connection reset错误

    切换到管理员,cmd下面执行:netsh advfirewall set global StatefulFTP disable MS对此的解释:https://technet.microsoft.co ...

  8. 大数据系列-java用官方JDBC连接greenplum数据库

    这个其实非常简单,之所以要写此文是因为当前网上搜索到的文章都是使用PostgreSQL的驱动,没有找到使用greenplum官方驱动的案例,两者有什么区别呢? 一开始我也使用的是PostgreSQL的 ...

  9. 手把手教你玩转nginx负载均衡(三)----配置虚拟服务器网络

    引言 虽然上一篇我们成功的启动了虚拟机,也安装好了操作系统,但是这台虚拟机和主机以及其他虚拟机是没有办法连通的,我们的目标是配置多台服务器并且配置nginx反向代理,来实现负载均衡,所以不能访问内网是 ...

  10. 移动端webapp自适应实践(css雪碧图制作小工具实践)图文并茂

    为什么要写这个 以前写过关于webapp自适应屏幕的文章(链接),不过写的大多数群众看不懂,所以来个图文并茂的版本.虽然只是一个简单的页面,不过在做的过程中也遇到了一些问题,也算是好事吧! 该示例gi ...