- 浏览: 509780 次
- 性别:
- 来自: 大连->北京
文章分类
最新评论
-
春天好:
写的很不错 推荐一个免费好用的云端爬虫开发平台不需要安装环境, ...
web爬虫 -
cpu88:
网络爬虫爬来爬去,网上信息可以瞬间扩散,但是也意味着,没有人愿 ...
web爬虫 -
biaoming:
牛。。学习了。。
MongoDB 关于索引的建议 -
biaoming:
楼主用mongo好早啊。
MongoDB 优化 -
biaoming:
好教程,学习了。。。
MongoDB 优化
穷举属性(Enumerating Properties)
要列出对象所有的属性可以用for.in循环来做
var o = {p1: 1, p2: 2}; for (var i in o) { console.log(i + '=' + o[i]); }
结果为:p1=1,p2=2
但是有以下几点需要注意
- 并不能把对象的所有属性列出来。像constructor属性就没有。可以列出的属性我们叫它可以枚举的(enumerable),可以用propertyIsEnumerable()方法来判断属性是否可以列出来。
- 可以把prototype的属性列出来,如果要判断对象的自身属性可以用hasOwnProperty() 方法
- 虽然可以列出所有prototype的属性,但是如果使用propertyIsEnumerable()方法来校验prototype的属性,它的返回结果都是false.
让我们看个综合例子就明白了
function Gadget(name, color) { this.name = name; this.color = color; this.someMethod = function(){return 1;} } Gadget.prototype.price = 100; Gadget.prototype.rating = 3;
创建一个新的对象
var newtoy = new Gadget('webcam','black');
for (var prop in newtoy) { console.log(prop + ' = ' + newtoy[prop]); }
结果为
name = webcam
color = black
someMethod = function () { return 1; }
price = 100
rating = 3
如果要区分自身属性和prototype属性,那就用hasOwnProperty()方法
for (var prop in newtoy) { if (newtoy.hasOwnProperty(prop)) { console.log(prop + '=' + newtoy[prop]); } }
结果为
name=webcam
color=black
someMethod=function () { return 1; }
再来看一下propertyIsEnumerable的方法
newtoy.propertyIsEnumerable('name');//true
大部分内置的属性和方法都是不可以列举的
newtoy.propertyIsEnumerable('constructor');//false
任何的属性来自prototype的都不能被列举
newtoy.propertyIsEnumerable('price');//false
如果进入prototype内部去调用属性就可以被列举了
newtoy.constructor.prototype.propertyIsEnumerable('price');//true
扩展内置对象
内置对象就是由构造函数Array,String,Object。函数可以扩展它们的prototype,也就意味着你可以通过prototype添加Array的功能。
Array.prototype.inArray = function(needle) { for (var i = 0, len = this.length; i < len; i++) { if (this[i] === needle) { return true; } } return false; }
现在所有的Array都有了新的方法。
var a = ['red', 'green', 'blue']; a.inArray('red');//true a.inArray('yellow');//false
通过prototype扩展Array的功能真是很简单的事情。
关于扩展内置对象的讨论
Prototype库是个比较有名的javascript库,它通过这种方法,把javascript变成了类似ruby的语言。但是YUI却反对这种做法。如果你会使用Javascript,一般希望用javascript正常的写法,改变了核心方法,会对开发人员造成许多困惑。
现在的javascript和浏览器功能都逐渐的增多,本身开发人员对Javascript核心的扩展,很可能明天就会没什么用处了。最佳实践是先判断核心的功能是否存在,然后再去扩展。如:
if (!String.prototype.reverse) { String.prototype.reverse = function() { return Array.prototype.reverse.apply(this.split('')).join(''); } }
关于prototype令人迷惑的地方
function Dog(){ this.tail=true; } var benji = new Dog(); var rusty = new Dog(); Dog.prototype.say = function(){ return 'Woof'; } benji.say();//Woof rusty.say();//Woof benji.constructor;//Dog() rusty.constructor;//Dog() benji.constructor.prototype.constructor;//Dog() typeof benji.constructor.prototype.tail;//undefined Dog.prototype={paws:4,hair:true}; //Dog.prototype.constructor = Dog; typeof benji.paws;//undefined alert(benji.say());//Woof var lucy = new Dog();//new object alert(lucy.paws); alert(lucy.tail) lucy.constructor;//Object(); benji.constructor;//Dog(): typeof lucy.constructor.prototype.paws;//undefined typeof benji.constructor.prototype.paws;//number
新建一个构造函数并创建两个对象
function Dog(){ this.tail=true; } var benji = new Dog(); var rusty = new Dog();
建完对象之后,我们仍然可以添加属性到prototype中,对象可以访问这个新添加的属性
Dog.prototype.say = function(){ return 'Woof'; } benji.say();//Woof rusty.say();//Woof
让我们来看看创建对象的构造函数,一起看来很正常
benji.constructor;//Dog() rusty.constructor;//Dog()
看如下代码很有意思的事情发生了。。。。。
benji.constructor.prototype.constructor;//Dog()
当我们想知道prototype的构造函数是啥的时候,问题出现了。。。结果是Dog()。但是这不完全正确。prototype对象仅仅是个Object对象,他并没有任何关于Dog的属性。。。测试看看
typeof benji.constructor.prototype.tail;//undefined
让我们继续深入下去。当完全重写prototype对象时看看会怎么样。
Dog.prototype={paws:4,hair:true};
发现了以前创造的对象竟然访问不了新的prototype的属性。。。
typeof benji.paws;//undefined benji.say();//Woof
说明了旧的对象还是指向以前的Prototype了。
让我们新建一个对象看看会怎样
var lucy = new Dog();//new object lucy.say();//TypeError:lucy.say is not a function lucy.paws;//4
说明新建的对象已经指向新的prototype了。
但是lucy这个对象的构造函数变成了object
lucy.constructor;//Object(); benji.constructor;//Dog():
最令人感到困扰的是prototype的属性
typeof lucy.constructor.prototype.paws;//undefined typeof benji.constructor.prototype.paws;//number
所以如果想完全重写prototype属性,建议用以下的方式。
Dog.prototype={paws:4,hair:true}; Dog.prototype.constructor=Dog;
这样就不会造成以上的困扰了。。。。
评论
发表评论
-
Javascript 基本数据类型,数组,循环以及条件 - 基本数据类型
2009-10-13 09:43 0你所使用的任意值都包含一个类型。在javascript中有如下 ... -
Javascript 基本数据类型,数组,循环以及条件 - 运算符
2009-10-12 21:41 1394运算符 运算符对一个或两个值(也可能是变量),进行一个 ... -
Javascript 基本数据类型,数组,循环以及条件-变量
2009-10-12 21:39 1892在深入javascript面向对象特性之前,让我们温习下基础知 ... -
Javascript 在浏览器环境中 (七) XMLHttpRequest
2009-02-17 17:19 2536XMLHttpRequest XMLHttpRequest是一 ... -
Javascript 在浏览器环境中 (六) 事件
2009-02-17 14:17 2686事件 事件的例子很多了。如用户输入,点击按钮等等。可以把一个j ... -
Javascript 在浏览器环境中 (五) HTML DOM
2009-02-12 13:56 1765已经知道了 DOM 适用于 XML和HTML文档。前几部分已经 ... -
Javascript 在浏览器环境中 (四) DOM节点的创建,修改与删除
2009-02-12 13:55 5997修改节点 上面一篇我们学习了DOM节点的访问,下面来看看DO ... -
Javascript 在浏览器环境中 (三) DOM节点的访问
2009-02-09 14:47 2463DOM DOM就是Document object Model的 ... -
Javascript 在浏览器环境中 (二) BOM
2009-02-05 17:25 1567BOM BOM是Browser Object Model的缩写 ... -
Javascript 在浏览器环境中 (一) 目录
2009-02-05 15:35 1340前言 大家都知道Javascript程序本身不能自己运行。需要 ... -
Javascript 继承 (七)
2009-02-05 15:21 1152混合使用原型继承和复制属性 当使用继承时,更多的是想在现有的功 ... -
Javascript 继承 (六)
2009-01-19 16:36 1119深度拷贝 上一节所说到的extendCopy再深一层的对象 ... -
Javascript 继承 (五)
2009-01-13 17:59 1157要注意复制引用。 很烦的是,在复制引用的时候,有的时候并不是期 ... -
Javascript 继承 (四)
2009-01-12 23:04 1199封装继承 通过上面的学习,我们把继承封装,这样就可复用了。代码 ... -
Javascript 继承 (三)
2009-01-06 00:33 1458从子对象中访问父对象。 经典的面向对象语言都有语法可以在子类中 ... -
Javascript 继承 (二)
2009-01-05 23:04 1449仅仅继承Prototype 添加可以重用的方法和属性到prot ... -
Javascript 继承 (一)
2008-12-31 15:32 1437关于继承前言 到这里如 ... -
Javascript Prototype (一)
2008-12-30 14:22 2203关于prototype 属性 函数(functions)在ja ... -
Javascript 对象 (四)
2008-12-29 16:20 1049函数返回对象 可以用构造函数来创建个对象,也可以通过普通函数返 ... -
Javascript 对象 (三)
2008-12-29 15:33 1137This var hero = { name : 'Ra ...
相关推荐
JavaScript中的`prototype`是一个核心概念,它涉及到对象继承和函数原型。在JavaScript中,每创建一个函数,该函数就会自动获得一个名为`prototype`的属性,这个属性是一个对象,用于实现对象间的继承。同时,每个...
JavaScript,作为一种广泛应用于Web开发的脚本语言,其高级特性如闭包(closures)、原型(prototype)和继承(inheritance)是理解其精髓的关键。本文将深入探讨这些概念,帮助开发者更好地掌握JavaScript的核心。 ...
JavaScript中的原型(Prototype)是理解JavaScript继承机制的关键概念。它是一种对象属性,允许一个对象访问并继承另一个对象的属性和方法。在这个“javascript prototype文档”中,我们可以期待深入学习JavaScript...
JavaScript Prototype 是一种重要的编程概念,尤其在Web开发中不可或缺。这个压缩包文件“JavaScript_Prototype(源代码+中文手册).rar”包含了关于JavaScript原型的源代码和中文手册,为学习和理解这一主题提供了...
### 二、Prototype 使用示例 1. **DOM操作示例**: ```javascript var element = $('myElement'); // 获取id为myElement的元素 element.insert('<p>Hello, World!</p>'); // 在元素内插入文本 ``` 2. **AJAX...
### JavaScript Prototype原型操作知识点 #### 一、Prototype基础概念 **Prototype** 在 JavaScript 中是一个非常重要的概念,它支持面向对象编程中的继承特性。每个 JavaScript 对象都有一个内部属性 `[...
#### 二、基本概念:使用`prototype`定义方法 在JavaScript中,通常情况下,当我们创建一个新对象时,会为该对象复制一份其构造函数中的方法。这种方法虽然简单直观,但在创建大量对象时会导致内存浪费,特别是在...
Prototype.js 是一个强大的JavaScript类库,它为开发者提供了丰富的功能,使得创建具有高度互动性和Web2.0特性的富客户端页面变得更为简单。这个库的设计理念是扩展JavaScript的基础对象,提供一套统一且易于使用的...
prototype.js是一个非常优雅的javascript基础类库,对javascript做了大量的扩展,而且很好的支持Ajax,国外有多个基于此类库实现的效果库,也做得很棒。 prototype.js不仅是一个有很大实用价值的js库,而且有很...
《Professional JavaScript Frameworks: Prototype,YUI, ExtJS, Dojo and MooTools》是关于JavaScript框架的高级编程资源,包含了各种知名框架的源代码,这些框架包括Prototype、YUI(Yahoo! User Interface Library...
JavaScriptprototype的深度探索不是原型继承那么简单.pdf
JavaScript中的`prototype`属性是面向对象编程的关键特性之一,它关联了函数(特别是构造函数)与实例之间的继承关系。每个函数都有一个`prototype`属性,这个属性是一个对象,包含了所有实例共享的方法和属性。当...
JavaScript中的`prototype`是理解面向对象编程的关键概念之一。它是一种机制,允许对象共享属性和方法,从而实现代码复用。在JavaScript中,每个函数(包括构造函数)都有一个内置的`prototype`属性,这个属性指向一...
javascript的prototype原型简单介绍: prototype原型是javascript中特别重要的概念,属于必须要掌握,如果没有良好的掌握的话,进一步用好或者学好js基本是不可能的实现的事情,并且此概念稍有难度,可能对于初次接触...
然而,原生JavaScript的API庞大且不统一,为了简化开发,社区创造了一系列的框架,其中jQuery、MooTools和Prototype是三个非常著名的JavaScript库。这些框架提供了一致的接口,增强了DOM操作,简化了事件处理,并...
**JavaScript原型(Prototype)库详解** JavaScript是一种动态类型的编程语言,其灵活性和强大的对象操作能力使其在Web开发中占据重要地位。"Prototype.js"是一个针对JavaScript的开源库,旨在增强和扩展JavaScript的...
二、使用 Prototype 定义对象类型 使用 prototype 来定义对象类型非常简单,只需要创建一个对象,并将其 prototype 属性指向一个对象,该对象包含了该对象类型的所有方法和属性。例如,我们可以创建一个 Person ...
在JavaScript中,每个函数都有一个`prototype`属性,这个属性是一个对象,它的作用是当试图访问一个对象的属性时,如果该对象自身没有这个属性,就会去查找它的原型对象,以此类推,直到找到属性或者到达原型链的...