日期:2014-05-17  浏览次数:20694 次

谁能帮我解释这段代码:A.prototype是怎么回事.
<HTML>
<HEAD>
<TITLE>TEST</TITLE>
<SCRIPT>
var Class = { 
create: function() { 
return function() { 
this.initialize.apply(this,arguments); 


}
var A = Class.create(); 
A.prototype={ 
initialize:function(v){ 
this.value=v; 
}
showValue:function(){
alert(this.value); 
}
}
</SCRIPT>
</HEAD>
<BODY>
ARE YOU READY?
</BODY>
</HTML>

以上代码哪里出错了...
A.prototype的作用...
return function() { 
this.initialize.apply(this,arguments); 
}中的this.initialize.apply(this,arguments); 是什么意思...

------解决方案--------------------





<HTML>
<HEAD>
<TITLE>TEST</TITLE>
<SCRIPT> 
var Class = {
create: function() {
return function() {
this.initialize.apply(this,arguments);
}
}
};
var A = Class.create();
A.prototype={
initialize:function(v){
this.value=v;
}
}
showValue:function(){
alert(this.value);
}

</SCRIPT>
</HEAD>
<BODY>
ARE YOU READY?
</BODY>
</HTML>
 
、、、、、、、、、、、、、、、、









一、 起因 
那天用到prototype.js于是打开看看,才看几行就满头雾水,原因是对js的面向对象不是很熟悉,于是百度+google了一把,最后终于算小有收获,写此纪念一下^_^。 
prototype.js代码片段

代码如下:
var Class = { 
create: function() { 
return function() { 
this.initialize.apply(this , arguments); 



// Class使用方法如下
var A = Class.create(); 
A. prototype={ 
initialize:function(v){ 
this .value=v; 

showValue:function(){ 
alert(this.value); 


var a = new A(‘helloWord!'); 
a. showValue();//弹出对话框helloWord!

l initialize是什么? 
l apply方法是干什么的? 
l arguments变量呢? 
l 为什么new A后就会执行initialize方法? 
寻找答案:

二、 Js的面向对象 
initialize是什么? 
只不过是个变量,代表一个方法,用途是类的构造函数。 
其具体功能靠js的面向对象支持,那么js的面向对象是什么样子的那?和java 的有什么相同与不同? 
看代码:

代码如下:
var ClassName = function(v){ 
this.value=v; 
this.getValue=function(){ 
return this.value; 

this.setValue=function(v){ 
this.value=v; 

}

那么JS中的函数和类有什么不同呢? 
其实是一样的,ClassName就是一个函数,当出现在new后面的时候就作为一个构造函数来构造对象。 


代码如下:
var objectName1 = new ClassName(“a”);//得到一个对象

其中objectName1就是执行ClassName构造函数后得到的对象,而在ClassName函数中的this指的就是new之后构造出来的对象,所以objectName1会后一个属性和两个方法。可以通过这样来调用他们:

代码如下:
objectName1.setValue(''hello''); 
alert(objectName1.getValue());//对话框hello 
alert(objectName1.value) ;//对话框hello

那么

复制代码 代码如下:
var objectName2 = ClassName(“b”);//得到一个对象

这样objectName2得到的是什么呢?显然是方法的返回值,这里ClassName只作为了一个普通的函数(虽然首字母大写了)。但是在之前写的ClassName中并没有返回值,所以objectName2会是undifinded那么“b”赋给谁了呢?在这并没有产生一个对象,而只是单纯的执行这个方法,所以这个“b”赋值给了调用这个方法的对象window,证据如下: 
var objectName2 = ClassName(“b”);//得到一个对象 
alert(window.value);//对话框b 
所以JS中的所有function都是一样的,但是用途可能是不同的(用作构造对象抑或是执行一个过程)。 
下面该回到主题了initialize是干什么的?

代码如下:
var Class = { 
create: function() {