我正在学习一个图书馆,看到一个例子,我不明白它是如何完成的? 在类的函数中,“this”变量包含该类的所有方法。 外面只提供公共方法。
受保护的方法更有趣。它们仅在继承的类中可用。 它是如何工作的?
请参阅以下文档中的示例:
/**
* A-class
*/
var ClassA = AWeb.class({
public : {
/**
* A-class constructor
*/
constructor : function() {
/* Private variable */
this.variable1 = "A";
this.calls = 0;
},
/**
* Function returns information about the object
*/
getInfo : function() {
this.incCalls();
return "variable1=" + this.variable1 + ", calls=" + this.calls;
}
},
protected : {
/**
* Protected function
*/
changeVariable1 : function( value ) {
this.variable1 = value;
}
},
private : {
/**
* Private function
*/
incCalls : function() {
this.calls++;
}
}
});
/**
* C-class
*/
var ClassC = AWeb.class({
extends : ClassA,
public : {
/**
* B-class constructor
*/
constructor : function() {
this.super();
this.changeVariable1( "C" );
},
/**
* Function returns extended information about the object
*/
getLongInfo : function() {
return this.incCalls !== undefined ? "incCalls visible" : "incCalls undefined";
}
}
});
/**
* Main project function
*/
function main() {
var a = new ClassA(),
c = new ClassC();
alert(
"a instanceof ClassA: " + (a instanceof ClassA) + "\n" +
"a instanceof ClassC: " + (a instanceof ClassC) + "\n" +
"a.getInfo " + (a.getInfo ? "exists" : "undefined") + "\n" +
"a.getLongInfo " + (a.getLongInfo ? "exists" : "undefined") + "\n" +
"a.changeVariable1 " + (a.changeVariable1 ? "exists" : "undefined") + "\n" +
"a.getInfo()=" + a.getInfo() + "\n\n" +
"c instanceof ClassA: " + (c instanceof ClassA) + "\n" +
"c instanceof ClassC: " + (c instanceof ClassC) + "\n" +
"c.getInfo " + (c.getInfo ? "exists" : "undefined") + "\n" +
"c.getLongInfo " + (c.getLongInfo ? "exists" : "undefined") + "\n" +
"c.changeVariable1 " + (c.changeVariable1 ? "exists" : "undefined") + "\n" +
"c.getInfo()=" + c.getInfo() + "\n" +
"c.getLongInfo()=" + c.getLongInfo()
);
}
答案 0 :(得分:0)
抱歉这个不准确的问题。我知道javascript中的继承原则。 我感兴趣的是在指定的库中实现继承。它有效,我测试了它。
库是免费的,但它有一个封闭的代码,无法读取它。 它适用于所有浏览器。
我将指定的代码包装到html页面中,请查看。
<!DOCTYPE HTML>
<html>
<head>
<title>Sample project</title>
<!-- Styles -->
<link rel="stylesheet" type="text/css" href="http://a-web.me/styles/default/a-web.css" >
<!-- Scripts -->
<script type="text/javascript" src="http://a-web.me/scripts/a-web.js"></script>
</head>
<body>
<script type="text/javascript">
/**
* A-class
*/
var ClassA = AWeb.class({
public : {
/**
* A-class constructor
*/
constructor : function() {
/* Private variable */
this.variable1 = "A";
this.calls = 0;
},
/**
* Function returns information about the object
*/
getInfo : function() {
this.incCalls();
return "variable1=" + this.variable1 + ", calls=" + this.calls;
}
},
protected : {
/**
* Protected function
*/
changeVariable1 : function( value ) {
this.variable1 = value;
}
},
private : {
/**
* Private function
*/
incCalls : function() {
this.calls++;
}
}
});
/**
* C-class
*/
var ClassC = AWeb.class({
extends : ClassA,
public : {
/**
* B-class constructor
*/
constructor : function() {
this.super();
this.changeVariable1( "C" );
},
/**
* Function returns extended information about the object
*/
getLongInfo : function() {
return this.incCalls !== undefined ? "incCalls visible" : "incCalls undefined";
}
}
});
/**
* Main project function
*/
function main() {
var a = new ClassA(),
c = new ClassC();
alert(
"a instanceof ClassA: " + (a instanceof ClassA) + "\n" +
"a instanceof ClassC: " + (a instanceof ClassC) + "\n" +
"a.getInfo " + (a.getInfo ? "exists" : "undefined") + "\n" +
"a.getLongInfo " + (a.getLongInfo ? "exists" : "undefined") + "\n" +
"a.changeVariable1 " + (a.changeVariable1 ? "exists" : "undefined") + "\n" +
"a.getInfo()=" + a.getInfo() + "\n\n" +
"c instanceof ClassA: " + (c instanceof ClassA) + "\n" +
"c instanceof ClassC: " + (c instanceof ClassC) + "\n" +
"c.getInfo " + (c.getInfo ? "exists" : "undefined") + "\n" +
"c.getLongInfo " + (c.getLongInfo ? "exists" : "undefined") + "\n" +
"c.changeVariable1 " + (c.changeVariable1 ? "exists" : "undefined") + "\n" +
"c.getInfo()=" + c.getInfo() + "\n" +
"c.getLongInfo()=" + c.getLongInfo()
);
}
</script>
</body>
</html>