JavaScript对象的概述

什么是对象,代表现实中的某个事物, 是该事物在编程中的抽象,多个数据的集合体(封装体),用于保存多个数据的容器

为什么要用对象,便于对多个数据进行统一管理

对象属于一种复合的数据类型,在对象中可以保存多个不同数据类型的属性。而对象的值就是引用类型的实例。

在javaScript 中引用类型是一种数据结构,用于将数据和功能组织在一起。它也常被称做为类,但 javaScript 中却没有这种东西(模拟)。

虽然 javaScript 是一门面向对象的语言,却不具备传统面向对象语言所支持的类和接口等基本结构。

在应用程序中的存储和传输数据而言,它是非常理想的选择。

对象的组成

属性:代表现实事物的状态数据,由属性名和属性值组成,属性名都是字符串类型, 属性值是任意类型

方法:代表现实事物的行为数据,是特别的属性==>属性值是函数

JavaScript对象的分类

内建对象:由ES标准中定义的对象,在任何的ES的实现中都可以使用。比如:Math String Number Boolean Function Object....

宿主对象: 由JS的运行环境提供的对象,目前来讲主要指由浏览器提供的对象,比如 BOM DOM

自定义对象:由开发人员自己创建的对象

  

javaScript对象的创建方法—使用new运算符创建对象

使用new关键字调用的函数,是构造函数constructor。构造函数是专门用来创建对象的函数

使用typeof检查一个对象时,会返回object

function objrun(){
  return '123';
}

var box = new Object();//创建了一个对象
console.log(typeof box); //object类型  即对象

//创建对象的属性字段
box.name = '李炎恢';
box.age = 28;
box.run = objrun();
//获取对象的属性字段,如果读取对象中没有的属性,不会报错而是会返回undefined
// 获取属性的两种方式:对象.属性名,对象['属性名']
console.log("我的名字叫"+box.name+",我今年"+box['age']+"岁了...........");
console.log(box.run);//调用对象中的方法

new 关键字可以省略

var box = Object(); //省略了 new 关键字

box.name = '黄家艾';
box.age = 43;

console.log("我的名字叫"+box.name+",我今年"+box['age']+"岁了...........");

javaScript对象的创建方法—使用字面量表示法

var box = {
  name : '李炎恢', //创建属性字段
  age : 28,
  run : function () { //对象中的方法
    return '运行';
  }
};
console.log("我的名字叫"+box.name+",我今年"+box['age']+"岁了...........");
console.log(box.run()) ;//调用对象中的方法

属性字段也可以使用字符串形式,如果要使用一些特殊的名字,则必须加引号

var box = {
  'name' : '李炎恢', //创建属性字段
  'age' : 28
};
box.name = 'tom' // 修改对象的属性值,语法:对象.属性名 = 新值
console.log("我的名字叫"+box.name+",我今年"+box.age+"岁了...........");

创建对象的时候使用字面量方式创建,但可以在给对象创建字段的时候使用传统方式

var box = {};     //字面量方式声明空的对象

box.name = '李炎恢'; //传统方式给对象创建字段属性
box.age = 28;

//属性的输出方式有两种
console.log (box.age); //点表示法输出
console.log("我的名字叫"+box['name']+",我今年"+box['age']+"岁了...........");//中括号表示法输出,注意需要加上引号

javaScript对象的创建方法—显示的构造函数来创建对象

任何一个函数只要被new运算符使用了,那么这个函数就可以变成构造函数

var M = function(){
  this.name = "o2";
}
var o2 = new M();
alert(o2.name);

javaScript对象的创建方法—Object.create()

var p = {
  name:"o3"
};
var o3 = Object.create(p)
console.log(o3.name); // o3

将对象作为函数的参数传递

在实际开发过程中,一般我们更加喜欢字面量的声明方式。因为它清晰,语法代码少,而且还给人一种封装的感觉。字面量也是向函数传递大量可选参数的首选方式。

function box(obj) { //参数是一个对象
  if (obj.name != undefined) //判断属性是否存在
    console.log(obj.name);
  if (obj.age != undefined)
    console.log(obj.age);
}
var obj={
  name : '李炎恢',
  age : 28
}
box(obj);

使用 delete 删除对象属性

var box = {
  name: '东方卡'
}
console.log(box.name);
delete box.name;
console.log(box.name);//已被删除,undefined

操作特殊属性的方式

如果要使用特殊的属性名,不能采用.的方式来操作,需要使用另一种方式:语法:对象["属性名"] = 属性值

读取时也需要采用这种方式。使用[]这种形式去操作属性,更加的灵活。在[]中可以直接传递一个变量,这样变量值是多少就会读取那个属性

什么时候必须使用['属性名']的方式:属性名不是合法的标识名,属性名(比如属性名是一个变量)不确定

var obj = new Object();
obj.name = "孙悟空";

obj["123"] = 789;
var n = "nihao";
obj[n] = "你好";
console.log(obj["123"]); // 读取对象中属性名为"123"的属性值:789
console.log(obj[n]); // 读取对象中属性名为"nihao"的属性值:你好

对象的属性值

JS对象的属性值,可以是任意的数据类型

var obj = new Object();

obj.test1 = true;
obj.test2 = null;
obj.test3 = undefined;

console.log(obj.test1) // true
console.log(obj.test2) // null
console.log(obj.test3) // undefined

甚至也可以是一个对象

var obj1 = new Object();

var obj2 = new Object();
obj2.name = "猪八戒";
obj1.test = obj2; // 将obj2设置为obj的属性

console.log(obj1.test); // { name: '猪八戒' }
console.log(obj1.test.name); // 猪八戒

in 运算符

通过该运算符可以检查一个对象中是否含有指定的属性,如果有则返回true,没有则返回false

语法:"属性名" in 对象

var obj = new Object();
obj.name = "猪八戒";

console.log(obj.name); // // 猪八戒
console.log(obj.age); // undefined,一个对象的某个属性的属性值为undefined,有可能是没有这个属性,也有可能是这个属性的属性值就是undefined
var obj = new Object();
obj.name = "猪八戒";

console.log(obj.name); // // 猪八戒
console.log(obj.age); // undefined

console.log("name" in obj); // 检查obj中是否含有name属性:true
console.log("age" in obj); // // 检查obj中是否含有age属性:false

枚举对象中的属性

使用for ... in 语句,语法:for(var 变量 in 对象){}

for...in语句 对象中有几个属性,循环体就会执行几次,每次执行时,会将对象中的一个属性的名字赋值给变量

var obj = {
  name:"孙悟空",
  age:18,
  gender:"男",
  address:"花果山"
};

for(var n in obj){
  console.log(n + ":" + obj[n]);
}

基本数据类型和引用数据类型的区别

基本数据类型:String Number Boolean Null Undefined

引用数据类型:Object

JS中的变量都是保存到栈内存中的,基本数据类型的值直接在栈内存中存储,值与值之间是独立存在,修改一个变量不会影响其他的变量

var a = 123;
var b = a;
a++;

console.log("a = "+a); // a = 124
console.log("b = "+b); // b = 123
var c = 10;
var d = 10;
console.log(c == d); // true,当比较两个基本数据类型的值时,就是比较值
console.log(c === d); // true

对象是保存到堆内存中的,每创建一个新的对象,就会在堆内存中开辟出一个新的空间

而变量保存的是对象的内存地址(对象的引用),如果两个变量保存的是同一个对象引用,当一个通过一个变量修改属性时,另一个也会受到影响

var obj1 = new Object();
obj1.name = "孙悟空";
var obj2 = obj1; // 讲obj1的引用赋值给obj2变量,obj2变量和obj1指向同一个对象
obj1.name = "猪八戒"; // 修改obj的name属性

console.log(obj1.name); // 猪八戒
console.log(obj2.name); // 猪八戒

obj2 = null; //设置obj2为null,也就是将obj2变量指向了null对象

console.log(obj1); // { name: '猪八戒' }
console.log(obj2); // null
var obj1 = new Object();
var obj2 = new Object();

obj1.name = "沙和尚";
obj2.name = "沙和尚";

console.log(obj1); // { name: '沙和尚' }
console.log(obj2); // { name: '沙和尚' }

// 比较两个引用数据类型时,它是比较的对象的内存地址,如果两个对象是一摸一样的,但是地址不同,它也会返回false
console.log(obj1 == obj2) // false
console.log(obj1 === obj2) // false

JavaScript的对象详解的更多相关文章

  1. javascript Error对象详解

    今天谈一下在IE浏览器下返回执行错误的Javascript代码所在的问题.其中在IE浏览器下,如果你使用了try-catch,那么当出现异常的时候,IE浏览器会传递一个Error对象. ~~~怎么通过 ...

  2. javaScript document对象详解

    Document对象内容集合 document 文挡对象 - JavaScript脚本语言描述———————————————————————注:页面上元素name属性和JavaScript引用的名称必 ...

  3. JavaScript arguments对象详解

    1. 什么是 arguments MDN 上解释: arguments 是一个类数组对象.代表传给一个function的参数列表. 我们先用一个例子直观了解下 JavaScript 中的 argume ...

  4. (转)javascript中event对象详解

    原文:http://jiajiale.iteye.com/blog/195906 javascript中event对象详解          博客分类: javaScript JavaScriptCS ...

  5. js对象详解(JavaScript对象深度剖析,深度理解js对象)

    js对象详解(JavaScript对象深度剖析,深度理解js对象) 这算是酝酿很久的一篇文章了. JavaScript作为一个基于对象(没有类的概念)的语言,从入门到精通到放弃一直会被对象这个问题围绕 ...

  6. JavaScript进阶知识点——函数和对象详解

    JavaScript进阶知识点--函数和对象详解 我们在上期内容中学习了JavaScript的基本知识点,今天让我们更加深入地了解JavaScript JavaScript函数 JavaScript函 ...

  7. 从mixin到new和prototype:Javascript原型机制详解

    从mixin到new和prototype:Javascript原型机制详解   这是一篇markdown格式的文章,更好的阅读体验请访问我的github,移动端请访问我的博客 继承是为了实现方法的复用 ...

  8. JavaScript严格模式详解

    转载自阮一峰的博客 Javascript 严格模式详解   作者: 阮一峰 一.概述 除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict m ...

  9. dom对象详解--document对象(二)

       dom对象详解--style对象 style对象 style对象和document对象下的集合对象styleSheets有关系,styleSheets是文档中所有style对象的集合,这里讲解的 ...

随机推荐

  1. SQL SERVER PIVOT与用法解释

    通俗简单的说:PIVOT就是行转列,UNPIVOT就是列传行 在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表: WEEK_INCOME(WEEK ),I ...

  2. 修改tomcat命令黑窗口的名字

    一.为什么要修改tomcat黑窗口的名字 同时启动多个tomcat时,不好区分,而给tomcat的命令窗口取名区分是个不错的选择,例如下面这个效果. 二.修改的方法 1.找到tomcat的bin目录下 ...

  3. linux /mac 下 go环境变量配置

    安装了go语言之后,还要设置路径,如果不设置路径,则执行 go 的时候会提示 go: command not found,提示的意思是没有这个命令行.这个是因为还没有设置PATH路径. 设置路径的方式 ...

  4. elementUI vue table status的状态列颜色变化和操作列状态显示(停用, 启用)

    <div id="app" style="display: none"> ... <el-table-column prop="st ...

  5. Java 开源博客 Solo 1.9.0 发布 - 新皮肤

    这个版本主要是改进了评论模版机制,让大家更方便皮肤制作,并发布了一款新皮肤:9IPHP. Solo 是一款一个命令就能搭建好的 Java 开源博客系统,并内置了 15+ 套精心制作的皮肤.除此之外,S ...

  6. Flutter 布局(五)- LimitedBox、Offstage、OverflowBox、SizedBox详解

    本文主要介绍Flutter布局中的LimitedBox.Offstage.OverflowBox.SizedBox四种控件,详细介绍了其布局行为以及使用场景,并对源码进行了分析. 1. Limited ...

  7. 你不可不知的Java引用类型之——ReferenceQueue源码详解

    定义 ReferenceQueue是引用队列,用于存放待回收的引用对象. 说明 对于软引用.弱引用和虚引用,如果我们希望当一个对象被垃圾回收器回收时能得到通知,进行额外的处理,这时候就需要使用到引用队 ...

  8. (其他)用sublime text3编写的html网页用浏览器打开出现中文乱码的原理及解决方法(转)

    最近发现Hbuler比较难用,换成sublime text3了,用了以前没用过的软件,就要学习他的操作,刚上手就出了点问题. 解决方法就是sublime text3以utf8 with bom保存. ...

  9. css的定义、用法、注释、命名规则、书写规范

    什么是css: css全名是层叠样式表(Cascading Style Sheets) CSS的作用:给html标签添加"样式",样式定义了如何显示 HTML 元素 标签是可以由自 ...

  10. Windows 10 运行原生Bash【Ubuntu】

    当前widnows用户的 AppData\Local\lxss 目录下安装了ubuntu,其中rootfs是和ubuntu安装的目录一致 bash进入的就是LINUX的SHELL,因此其二进制格式是E ...