本文是金旭亮老师网易云课堂的课程笔记,记录下来,以供备忘。

对象的创建

JavaScript对象有两种类型
 
1).Native:在ECMAScript标准中定义和描述,包括JavaScript内置对象(数组,日期对象等)和用户自定义对象。
 
2).Host:在主机环境(如浏览器)中实现并提供给开发者使用,比如windows对象和所有的DOM对象
 
 
 

对象的含义

Object is an unordered collection of properties each of which contains a primitive value, object, or function.
                                                                                                                                                                                    ——ECMA-262
 
 
 
 

创建对象

1.)定义空对象之后再添加成员

      最简单的方法(称为object literal,对象字面量):
 var myObject = {};

之后便可以向它添加新成员:

 myObject.name = "张三";
myObject.age = ;

2).使用对象字面量

对象字面量就是包围在一对花括号中的零或多个“name/value"对。

         //通过对象字面量创建对象 属性的名字可以加也可以不加双引号
var person = {
"name": "张三",
age:
};

嵌套的对象定义

使用对象字面量方式,定义嵌套的对象很容易

         //使用字面量创建嵌套的对象
var embedObj = {
info: "information",
//内嵌的对象
inner: {
id: ,
value:
},
//内嵌的数组
arr: ["one", "two", "three"]
};

定义对象方法

 1).对象的方法,其实是一个“函数”类型的属性,可以使用对象字面量方式定义:
         //定义对象方法
var obj = {
sayHello: function (name) {
console.info("你好," + name + "!");
}
};
obj.sayHello("qiu"); //你好,qiu

2).也可以直接追加到现有对象中.

         var obj2 = {};
obj2.sayHello = function (name) {
console.info("你好," + name + "!");
};

对象的使用

[].表示法访问对象属性.可以通过||指定默认值 
 
         //访问对象
var exampleObj = {
info: "information",
//内嵌的对象
inner: {
id: ,
value:
},
//内嵌的数组
arr: ["one", "two", "three"],
//方法
sayHello: function (name) {
console.info("你好," + name + "!");
}
};
//使用点表示法访问对象属性
console.info(exampleObj.info); //information
console.info(exampleObj.inner.value); //
console.info(exampleObj.arr[]); //one
//如果要访问的属性不存在,可以使用||指定默认值
console.info(exampleObj.notExist || "属性默认值"); //属性默认值
//使用[]访问对象属性
console.info(exampleObj['info']); //information
//调用对象方法
exampleObj.sayHello('张三'); //你好,张三
exampleObj['sayHello']('李四'); //你好,李四

枚举对象属性

 因为对象可看成是属性的集合,因此可以通过迭代的方式获取其所有属性:
         //编程列出exampleObj对象的属性与方法
for (var p in exampleObj) {
console.info(p+ "类型:" + (typeof exampleObj[p]) );
}
// info类型:string
// inner类型:object
// arr类型:object
// sayHello类型:function

对象的属性可以随时添加与删除

         //删除对象的属性与方法
delete exampleObj.info;
delete exampleObj.sayHello;

删除一个对象属性之后,再对它进行访问,将得到一个undefined。

         //验证属性己删除
console.info(exampleObj.info);//undefined
console.info(exampleObj.sayHello === undefined); //true
//exampleObj.sayHello('张三'); //TypeError

处理TypeError:

            当JavaScript引擎在解析JavaScript代码时,如果出现TypeError异常,它将中断解析工作,导致后面的代码不会被执行,为了避免出现这种情况,可以使用&&运算符提前“取消”本条语句的执行,继续执行后面的代码:

 //使用&&避免出现TypeError导致后继代码无法执行
exampleObj.sayHello && exampleObj.sayHello('张三');
//尽管sayHello方法己被删除,上述代码得到一个undefined
//但后面的代码仍然可以继续执行

对象作为函数参数

示例:
         //作为函数参数的对象
function displayPerson(person) {
console.info('name=' + (person.name || '无名氏'));
console.info('age=' + (person.age || -));
};
//使用对象字面量直接将对象传入
displayPerson({
"name": "张三",
"age":
}); //name=张三
//age = 29
displayPerson({}); //name=无名氏
//age=-1
 
 
 
 
 
 

Javascript我学之五对象的创建与使用的更多相关文章

  1. Javascript我学之六对象工厂函数与构造函数

    本文是金旭亮老师网易云课堂的课程笔记,记录下来,以供备忘. 概述 使用对象字面量,或者向空对象中动态地添加新成员,是最简单易用的对象创建方法. 然而,除了这两种常用的对象创建方式,JavaScript ...

  2. 《JavaScript高级程序设计》读书笔记--(4)对象的创建

    ECMAScript支持面向对象(OO)编程,但不使用类或者接口.对象可以在代码执行过程中创建或增强,因此具有动态性而非严格定义的实体.在没有类的情况下,可以采用下列模式创建对象. 对象的创建 工厂模 ...

  3. JavaScript对象的创建之使用json格式定义

    json: javascript simple object notation. json就是js的对象,但是它省去了xml中的标签,而是通过{}来完成对象的说明. 定义对象 var person = ...

  4. JavaScript DOM高级程序设计2.1创建可重用的对象--我要坚持到底!

    1.对象中包含什么 在javascript中,从函数到字符串实际上都是对象 继承 //创建一个person对象的实例 var penson={}; person.getName=function(){ ...

  5. JavaScript对象的创建

    原文 简书原文:https://www.jianshu.com/p/6cb1e7b7e379 大纲 前言 1.简单方式创建对象的方法 2.工厂模式创建对象 3.构造函数模式创建对象 4.原型模式创建对 ...

  6. JavaScript(对象的创建模式)

    JavaScript和其他语言略有不同,在JavaScript中,引用数据类型都是对象(包括函数).不过,在JavaScript中并没有“类”的概念,这决定了在JavaScript中不能直接来定义“类 ...

  7. JavaScript 对象的创建和操作

    <script>         // 对象是属性的无序集合,每个属性都是一个名/值对. 属性名称是一个字符串.         // 对象种类         // 内置对象(nativ ...

  8. JavaScript面向对象—对象的创建和操作

    JavaScript面向对象-对象的创建和操作 前言 虽然说在JavaScript编程语言中,函数是第一公民,但是JavaScript不仅支持函数式编程,也支持面向对象编程.JavaScript对象设 ...

  9. JavaScript对象的创建之基于构造方法+原型方式

    为了解决原型所带来的问题,此处需要通过组合构造方法和原型来实现对象的创建,将属性在构造方法中定义,将方法在原型中定义.这种有效集合了两者的优点,是目前最为常用的一种方式. function Perso ...

随机推荐

  1. Python开发第一篇

    Python 是什么? 首先他可能是比较好的一个编程开发语言!

  2. Nginx安全相关配置和nginx.conf中文详解

    一.centos下redis安全相关 1.背景 在使用云服务器时,如果我们的redis关闭了protected-mode模式,被病毒攻击的可能会大大增加,因此我们使用redis时候,最好更改默认端口, ...

  3. BZOJ4241历史研究——回滚莫队

    题目描述 IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. 日记中记录了连 ...

  4. mpvue——支持less

    安装 安装less和less-loader,我用的是淘宝源,你也可以直接npm $ cnpm install less less-loader --save 配置 打开build目录下的webpack ...

  5. 利用 Python_tkinter 完成 2048 游戏

    成品展示 具备基本的数据合并以及分数统计,不同数字的色块不同 产生随机数, 数据无法合并判定以及重新开始选项 同时可以判定游戏失败条件 需求分析 完成基本数据合并算法 游戏结束条件 界面展示 重置按钮 ...

  6. 20175209 《Java程序设计》第三周学习总结

    20175209 <Java程序设计>第三周学习总结 教材学习内容总结 第四章知识点 1.发展阶段: 面向机器——面向过程——面向对象(特点:封装性,继承性,多态性) 2.类: 类 声明变 ...

  7. MFC(1):vc6.0转vs2005出现的问题

     在将vc6.0程序转换到vs2005或者vs2008.vs2010时提示:error C2440: 'static_cast' : cannot convert from 'UINT (__this ...

  8. Pandas系列(四)-文本数据处理

    内容目录 1. 为什么要用str属性 2. 替换和分割 3. 提取子串 3.1 提取第一个匹配的子串 3.2 匹配所有子串 3.3 测试是否包含子串 3.4 生成哑变量 3.5 方法摘要 一.为什么要 ...

  9. CentOS7.2 设置静态ip

    先找到配置文件: [root@localhost bin]# cd /etc/sysconfig/network-scripts [root@localhost network-scripts]# l ...

  10. Run Configurations(Debug Configurations)->Arguments里填写program arguments和VM arguments

    如图: 1.program arguments存储在String[] args里 2.VM arguments设置的是虚拟机的属性,是传给java虚拟机的.KV形式存储的,是可以通过System.ge ...