<html>
<head>
<script>
function SuperClass()
{
    var self = this;
    self.someVariable = true;
}
function SubClass()
{
    var self = this;
    self.name = "Sub";
}
SubClass.prototype = SuperClass;
var sub = new SubClass();
alert("This is a sub class with name " + sub.name + " and variable " + sub.someVariable);
</script>
</head>
<body>
</body>
开发者_如何学Go</html>
output:
This is a sub class with name Sub and variable undefined
So how come sub class doesnt have someVariable? I thought thats the whole point of prototyping.
You are simply assigning a reference to the SuperClass constructor to the SubClass.prototype, you need to use the new operator to make this SubClass.prototype object an instance of SuperClass:
//...
SubClass.prototype = new SuperClass();
//..
You may want to restore the constructor property of the SubClass.prototype object after the above line, because if you don't do it, the instances created with SubClass (like sub in your example) will have an inherited constructor property wrongly pointing to SuperClass:
SubClass.prototype.constructor = SubClass;
Check an example here.
Recommended articles:
- Constructors considered mildly confusing
- Object Oriented Programming in JavaScript
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论