首页
学习
活动
专区
圈层
工具
发布

JavaScript 对象所有API解析【2020版】

_route } }) 以下是正文,祝阅读愉快~ 之前看到【深度长文】JavaScript 数组所有 API 全解密[2]和JavaScript 字符串所有 API 全解密[3]这两篇高质量的文章。...刚好我看到《JavaScript 面向对象编程指南(第 2 版)》,觉得有必要写(或者说 chao)一下,也好熟悉下对象的所有 API 用法。...Object.prototype 该属性是所有对象的原型(包括 Object对象本身),语言中的其他对象正是通过对该属性上添加东西来实现它们之间的继承关系的。...,该方法就会返回true,而且,当前对象所在原型上的所有对象都能通过该测试,并不局限与它的直系关系。...(source)的所有可枚举的属性复制到目标对象(target)。

1.2K20

JavaScript之面向对象学习二(原型属性对象与in操作符)获取对象中所有属性的方法

结合使用 在使用for-in循环时,返回的是所有能够通过对象访问的、可枚举的属性,既包括实例中的属性又包括原型对象中的属性; 注意:屏蔽了原型中不可枚举属性(即将[[Enumerable]]设置为false...3、使用Object.keys()方法获取指定对象中所有可枚举的实例属性 ECMAScript 5中提供了Object.keys()方法。...这个方法接收一个对象作为参数,返回一个包含所有可枚举属性的字符串数组,代码如下: function Person(){ } Person.prototype.name="张三";...; //Object.keys(Person.prototype)=》获取原型属性对象的所有属性名,是键不是值 alert(keys); //输出name、age、job、sayName...personkeys); //输出:name、age var allkeys=Object.getOwnPropertyNames(Person.prototype); //获取Person构造函数原型对象的所有属性

2.4K90
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript 对象 — 重学 JavaScript

    其实这个正是所有的面向对象编程的一个基础,也就是说,他是这条鱼就是这条鱼,不是这条鱼就不是这条鱼,不会因为对象本身的状态改变而变得有区别。 所以我们对对象的认知是?...JavaScript 这个语言比较接近 “分类” 这个思想,但是它也不完全是分类的思想,因为它是一个多范式的面向对象语言。...Object —— Prototype(原型) 接下来我们讲一讲 JavaScript 描述对象的方式。...原型里面也会有一个最终版的原型叫 Object Prototype,这个就是所有物品的典型的物品,也可以说是我们所有对象的老祖宗。我们描述任何对象都是从它与描述对象的区别来进行描述的。...如果我们用 JavaScript 的具体的设施来描述,那这个 Nihilo 原型就是 null,这个大家就很容易理解了,我们很容易就可以建立一个 null 对象的原型。

    1.5K31

    JavaScript 中的对象

    对象 JavaScript 中的对象,Object,可以简单理解成“名称 - 值”对(而不是键值对:现在,ES 2015 的映射表(Map),比对象更接近键值对),不难联想 JavaScript 中的对象与下面这些概念类似...正因为 JavaScript 中的一切(除了核心类型,core object)都是对象,所以 JavaScript 程序必然与大量的散列表查找操作有着千丝万缕的联系,而散列表擅长的正是高速查找。...“名称”部分是一个 JavaScript 字符串,“值”部分可以是任何 JavaScript 的数据类型——包括对象。这使用户可以根据具体需求,创建出相当复杂的数据结构。...有两种简单方法可以创建一个空对象: var obj = new Object(); 和: var obj = {}; 这两种方法在语义上是相同的。...第二种更方便的方法叫作“对象字面量(object literal)”法。这种也是 JSON 格式的核心语法,一般我们优先选择第二种方法。

    4.5K20

    JavaScript——对象的属性

    在JavaScript中,所有的对象都是一组属性的集合,属性可以是数值,字符串等原始类型,也可以是函数,或者是其他对象。 属性的类型 JavaScript中的属性有两种类型:数据属性和访问器属性。...属性的特性 ES5开始,JavaScript为属性提供了三个特性用于描述其各种特征。特性是内部值,不能直接访问。...里对象的属性是以键/值对的形式存在的,这里的「键」不限于字符串类型,也可以是数值或其他对象。...事实上,JavaScript中的数组(Array),本质上也是一个键/值对的集合,数值类型的自然索引也是作为属性名(键)存在的。...() 获取属性定义信息 属性访问相关 Object.keys() 获取对象的所有属性名,仅限于可枚举的自身属性 Object.getOwnPropertyNames() 获取对象的所有属性名,包括可枚举和不可枚举

    4.3K30

    JavaScript 对象

    对象 对象(object)是 JavaScript 语言的核心概念,也是最重要的数据类型。 什么是对象?简单说,对象就是一组“键值对”(key-value)的集合,是一种无序的复合数据集合。...该对象内部包含两个键值对(又称为两个“成员”),第一个键值对是foo: 'Hello',其中foo是“键名”(成员的名称),字符串Hello是“键值”(成员的值)。键名与键值之间用冒号分隔。...两个键值对之间用逗号分隔 对象的所有键名都是字符串(ES6 又引入了 Symbol 值也可以作为键名),所以加不加引号都可以。上面的代码也可以写成下面这样。...var obj = { p: function (x) { return 2 * x; } }; obj.p(1) // 2 如果属性的值还是一个对象,就形成了链式引用。...var o1 = {}; var o2 = { bar: 'hello' }; o1.foo = o2; o1.foo.bar // "hello" 查看所有属性 查看一个对象本身的所有属性,可以使用

    99620

    JavaScript 对象

    JavaScript 中的所有事物都是对象:字符串、数值、数组、函数... 此外,JavaScript 允许自定义对象。...所有事物都是对象 JavaScript 提供多个内建对象,比如 String、Date、Array 等等。 对象只是带有属性和方法的特殊数据类型。 布尔型可以是一个对象。 数字型可以是一个对象。...创建 JavaScript 对象 通过 JavaScript,您能够定义并创建自己的对象。 创建新对象有两种不同的方法: 使用 Object 定义并创建对象的实例。...使用 Object 在 JavaScript 中,几乎所有的对象都是 Object 类型的实例,它们都会从 Object.prototype 继承属性和方法。...[x]; } JavaScript 的对象是可变的 对象是可变的,它们是通过引用来传递的。

    16410

    面向对象的JavaScript

    什么是对象,面向对象(Object-Orented,OO)的抽象 从前在Javascript王国里有一个国王,他觉得世界上最美妙的声音就是鸭子的叫声,于是国王召集大臣,要组建一个1000只鸭子组成的合唱团...现在可以慢慢理解面向对象编程的三个特点了。"的卢"属于世间万物(window),也属于我们所封装的马类对象,继承了它所有父级的特点,具有万物特点比如具有window下的常用属性。...prototype——混合模式 prototype:原型 javascript中,只要是函数,都有一个隐藏的prototype属性。它指向一个对象,这个对象包含了所有实例都可以使用的对象和方法。...(); 换句话说,原型模式是给一类(严格来说javascript没有类)的对象添加方法。...有了prototype,实例的被定义来的方法可以放一块。类和构造函数其实是一个东西。 构造函数在调用时需要new。所以构造函数首字母大写。 属性:每个对象不同,但方法所有对象都相同。

    1K10

    JavaScript对象的继承

    JavaScript 对象的继承 1. 原型链继承 基于原型链,即把一个对象的原型设置为另一个对象的实例,那么这个对象实例也就拥有了另一个对象上的属性。...```JavaScript s instanceof Son _//true_ s instanceof Father _//true_ _```_ 子类也可以继续添加其他的方法,但是需要注意,子类添加方法的代码要写在替换原型的代码之后...借用构造函数 使用父类的实例设置为子类的原型,也就意味着父类的属性变成了子类原型上共享的属性了。我们在之前将面向对象时,说过,对象的属性最好定义在构造函数中,需要共享的引用类型的属性再定义在原型上。...当继承的父对象不是自定义类型和构造函数的情况下,可以采用寄生继承模式。 5. 寄生组合式继承 组合继承模式是最常用的模式,但也不是完美的。组合继承会执行两次父类构造函数。...ES6 中类的继承 在 es6 中,有了 class(JavaScript 的 class 只是一种语法糖,覆盖在基于构造函数和原型的模式上),我们就可以使用 extends 来实现类的继承了: class

    1.1K20

    JavaScript——对象的原型

    如机制和原理(对象基于原型)里所记述的那样,JavaScript是一个基于原型的面向对象的语言。本文着重于对原型的实现机制进行剖析和说明。...原型链的实现 JavaScript里所有的对象都有一个名为__proto__的属性,这个属性里面存放的就是对象所参照的原型对象的引用。 ?...原型的自动设置 当通过构造函数创建新对象时,JavaScript会自动将构造函数的prototype属性值设置到新对象的__proto__属性里。...var tom = new Person("Tom"); 上面创建Person对象的代码与下面的程序逻辑是等价的,事实上JavaScript也是这样执行的。...__proto__ = Person.prototype; tom = Person.call(tom,"Tom"); 属性的继承 当访问对象的属性时,JavaScript会通过遍历原型链进行查找,直到找到给定名称的属性为止

    80810

    javascript简介_javascript对象

    JavaScript中ActiveXObject对象是启用并返回 Automation 对象的引用。...要赋值为 ActiveXObject 的变量名。 servername是必选项。提供该对象的应用程序的名称。 typename是必选项。要创建的对象的类型或类。 location是可选项。...创建该对象的网络服务器的名称。 Automation 服务器至少提供一类对象。例如,字处理应用程序可能提供应用程序对象、文档对象和工具栏对象。   ...使用JavaScript中的ActiveXObject填充并设置Excel格式2006年12月19日 星期二 下午 05:131.创建一个新Excel表格 var XLObj = new ActiveXObject...本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    2.8K20

    JavaScript的对象引用

    toobug的圈圈图 创建对象{test:1},并将该对象在内存的引用地址,传递给a变量,a变量的值是对象{test:1}的引用。 复制a的值给变量b,也就是,b也获得了对象{test:1}的引用。...对b.test重新赋值为2,由于b是{test:1}的引用,实则是{test:1}这个对象的test属性的值变更为2。 嗯,这个坑,估计一个不小心就会踩到。...Demo.2 var a = {test: 1}; var b = a; b = {test: 2}; console.log(a.test) 嗯,别被惯性思维给坑了,这里的b变量,被赋值了两次,两次都是不同的对象...嗯,刚才被实例化的对象,没有了外部引用之后,GC可以开始干活鸟。 再赋值一次,一个新的对象又被实例化了。 结语: 感谢好导师TooBug,基础讲解生动活泼。...一个作用域内部的函数,return并且被外部对象给引用之后,函数本身居然给实例化了,其内部私有变量也给持久性的保存了。除非引用断掉,否则GC都无法回收。

    1.5K00

    Javascript的对象拷贝

    正文共:1628 字 预计阅读时间:6分钟 ---- 翻译:疯狂的技术宅 原文:https://smalldata.tech/blog/2018/11/01/copying-objects-in-javascript...Javascript 的对象只是指向内存中某个位置的指针。这些指针是可变的,也就是说,它们可以重新被赋值。所以仅仅复制这个指针,其结果是有两个指针指向内存中的同一个地址。...通过上面的例子可以看到,对象 foo 和 bar 都能随着对方的变化而变化。所以在拷贝 Javascript 中的对象时,要根据实际情况做一些考虑。...如果对象的属性也是对象,那么实际被拷贝的只是那些指针,这跟执行 var bar = foo; 的效果是一样的,和第一段代码中的做法一样。...结论 Javascript 中最好的对象拷贝的算法,很大程度上取决于其使用环境,以及你需要拷贝的对象类型。

    70820

    JavaScript——对象

    对象 在现实生活中,万物皆对象,对象是一个具体的事物,看得见摸得着的实物。 例如:一本书、一辆汽车、一个人都可以是“对象”,而一个数据库、一个网页、一个与远程服务器的连接也可以是“对象”。...在JavaScript中,对象是一组无序的相关属性和方法的集合,所有的事物都是对象,例如字符串、数值、数组、函数等。...对象是由属性和方法组成的 属性:事物的特征,在对象中用属性来表示(常用名词) 方法:事物的行为,在对象中用方法来表示(常用动词) 为什么需要对象?...在JavaScript中,现阶段我们可以采用三种方式创建对象(object): 利用字面量创建对象 对象字面量:就是花括号{}里面包含了表达这个具体事物(对象)的属性和方法。...构造函数和对象的联系: 构造函数抽象了对象的公共部分,封装到函数里面,泛指的某一大类,它类似于Java语言里面的类(class) 对象特指某一个,通过new关键字创建对象的过程我们也称为对象实例化 new

    85010
    领券