Javascript对象

对象

在JavaScript里几乎所有东西都是对象或者用起来像对象,理解了对象就能够理解JavaScript。对象是一组有命名值(也称为属性)集合的容器。

  • user
property property value
living true
age 20
gender male

以上“user”一词是一组属性名和对应值得标签,这些属性和值构成了user。然而,JavaScript不会用表格表达,它是用对象来表达的,将上述表格转换成实际的JavaScript对象:

//方法一
var user = new Object();
user.living = true;
user.age = 20;
user.gender = 'male';

//方法二
var user = function user(living,age,gender) {
    this.living = living;
    this.age = age;
    this.gender = gender;
}

对象只是属性的容器,每个属性都有一个名称和一个值。JavaScript采用具有具有命名值属性的容器(即对象);方法是包含Function()对象的属性,其目的是对函数内部的对象进行操作。


数组也是对象:

var myArray = new Array();
console.log(typeof myArray);        //Object

JavaScript内置对象构造函数

JavaScript语言包含9个原生(或内置)对象构造函数,使用这些对象来构建JavaScript语言。原生对象构造函数是多方面表达的,即它们可以生成对象,也可以被用于促进语言的编程约定的形成。如,函数是Function()构造函数创建的对象,作为构造函数,使用new关键字调用后,它们也可以用于创建其他对象。

  • Number()
  • String()
  • Boolean
  • Object()
  • Array()
  • Function()
  • Data()
  • RegExp()
  • Error()

Math对象是一个静态对象,而不是构造函数。Math只是一个由JavaScript设置的对象命名空间,用于存储数学函数。

原生对象也被成为“全局对象”。

JavaScript提供了叫做“字面量”的快捷方式——用于创建大多数原生对象,而不必使用new这样的方式。大多数情况下,字面量语法与使用new操作符的效果相同。但是也有例外:Number()、String()和Boolean()。

在针对字符串、数字和布尔值使用字面量值时,只有在该值被视为对象的情况下才会创建实际的对象,如(var str = 'foo'.length)之前一直在使用原始数据类型

原始值

"foo"、true、false,以及null和underfind等都被视为原始值,因为它们是不可细化的。也就是说,它们就是它们,不可能像对象更为复杂。与使用字面量语法创建值相反,使用new创建的String()、Number()或Boolean() 创建的对象实际上是一个复杂的对象。

var str1 = 'hello';
var str2 = new String('hello');
console.log(str1===str2);       //false

原始值不是对象。原始值的特殊之处在于它们是用于表示简单值。原始值是按值存储的,而复杂值是按引用来存储的。

复杂对象

复杂对象里存储的并不是简单的值,而是该对象的引用,所以,试图复制一个复杂对象的时候并不是真正的复制了这个对象的值,而是获取了该对象的引用。

let user1 = {
    name : 'wcry',
    age : 20,
    gender : 'male'
};
let user2 = user1;
console.log(user1,user2);           //name = 'wcry'
user2.name = 'wsmile';
console.log(user1,user2);           //name = 'wsmile'

typeof操作符

typeof操作符返回变量的类型,但是有的时候比较特殊,需要注意。以下为特例:

let myNull = null;
let myUnderfined = undefined;
let myFunction = new Function('x','y','return x+y');
let myRegExp = new RegExp('\\bt[a-z]+\\b');
console.log(typeof myNull);             //object
console.log(typeof myUnderfined);       //undefined
console.log(typeof myFunction);         //function
console.log(typeof myRegExp);           //Object
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容