Javascript对象,prototype链
Doc链接: http://docs.google.com/Doc?docid=0AZUdXGtQa0xqZGRocmo3MzZfMjA2Y2ZqZ2szZ2g&hl=en
关键词:JavaScript;对象;prototype;prototype链
我们来打个比方吧:
随着个人电脑硬件的白菜价化,很多硬件制造商开始帮用户做整机DIY。有时候用户可能回到“总部”去装机,那里东西很全。但一般这些厂家在各个小地方也有网点,你可以就近去装机,他也提供所有的配件。但这里这些网点自己并没有配件,而是当用户要的时候他们便去总部拿,有些硬件总部也没有,这时总部在向生产商拿... 最终可能会到生产流水线上。但这一切对装机的人来说是不需要关心的,他只知道你是装机网点,我要什么东西(当然局限在电脑硬件)你都能提供。同时这些厂家也不会在任何一个网点放置所有的硬件,只是有需要的时候会向上一级取。
这套东西就是我要说的JavaScript中的对象到底是怎么工作的:prototype链,就像这种硬件供应商不断向自己的上一级去取一样的效果。
如果你不想关系OOP(面向对象编程)的话,完全没必要去关心这个话题。(这里能不能叫OOP以后再理解吧)
首先还是要说一下js的原生对象,包括:Array、Number、RegExp、Function、Object... 这里不一一列举的,列举这些东西的文档到处都是。
当我们用这些原生对象的时候可以理解为他们就是系统提供的“类”,我们可以这样定义一个对象:
var obj = new Object();
obj.x = "hello world"; // 这样会动态的给obj添加一个“成员变量”,应该叫属性
这里就可以理解我们创建了一个Object类的实例obj。obj可以使用Object的方法obj.toString()等等。
这一切“长的”都很像Java、c++那样的类、实例的行为。但我们在下面将看到,其实不是这样的...
js是一个prototype语言
prototype(原型),如果你知道这个概念,那是最好。如果不知道,我这里会做一些介绍,但不是官方的,深入的理解请看其他资料。
prototype,prototype,prototype,prototype,prototype,prototype,prototype ...
先把他背下来吧,prototype到底干啥的?原型?不理解... 没关系,记住它
这里我先声明几点(不一定正确,但对你当前理解下面的行为会有很好的帮助,当看不懂的时候就来看这几条)
1. js里没有“类”这一概念,是根本就没有。
2. js里的最常用的东西就是Object(以下都称为对象),他有点像一个hash map,一个键值对集合,一般我们习惯写成
相关文档:
匿名函数
函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途。匿名函数:就是没有函数名的函数。
1、函数的定义,首先简单介绍一下函数的定义,大致可分为三种方式
第一种:这也是最常规的一种
function double( x ){
return 2 * x;
}
第二种:这种方法使用了Func ......
*------------------------------------------------------
*说明:select元素javascript常用操作
* 1.判断是否存在指定value的Item
* 2.加入一个Item
* 3.删除值为value的所有Item
* 4.删除某一个index的选项
  ......
// 下面代码块实现了string.parseJSON方法
(function(s){
// This prototype has been released into the Public Domain, 2007-03-20
// Original Authorship: Douglas Crockford
// Originating Website: http://www.JSON.org
// Originating URL : http://www.JSON.o ......
web开发中有时需要对输入框中的时间(主要是开始时间和结束时间)进行比较,网上搜索了一番,发现有不少是无效的,以下方法经小弟检验确实有效,特此共享。(请关注红色部分)
function ValidtorTime(){
var d1 = new Date(document.getElementById('txbfromDate').value.replace(/\-/g, "\/"));
var d2 = new Date(do ......