所以我正在设计一个成绩簿界面,我的课程定义为:
<script>
course = new Object();
var name;
var gradingareas;
var finalgrade;
</script>
然后我想创建一个新实例:
var gradingareas = new Array("Homework", "Classwork", "Exams");
course1 = new course("CS1500", gradingareas, 85);
我也试过没有前面的var无济于事。我得到一个“未捕获的TypeError:对象不是一个函数”我是一个非常新的JavaScript,所以我甚至不知道我是否正确的方式。任何帮助表示赞赏谢谢。
答案 0 :(得分:53)
您现有的代码:
// Creates a new, empty object, as a global
course = new Object();
// Creates three new variables in the global scope.
var name;
var gradingareas;
var finalgrade;
变量与对象之间没有联系。
看起来你想要更像的东西:
function Course(name, gradingareas, finalgrade) {
this.name = name;
this.gradingareas = gradingareas;
this.finalgrade = finalgrade;
}
然后:
var course1 = new Course("CS1500", gradingareas, 85);
请注意使用大写字母命名构造函数。这是JS社区的惯例。
答案 1 :(得分:37)
JS是典型的,而不是基于类的,如果你是新手,那么立即学习它有利于而不是试图从中汲取经典的继承模型,但是,经典的继承在JS中很有用。
无论如何,要回答如何访问变量:
course1.name
可以正常使用上面的示例。
如果您想要对数据进行私有化,可以使用闭包来采用这种方法:
var Course = function(name, grade) {
// Private data
var private = {
name: name,
grade: grade
}
// Expose public API
return {
get: function( prop ) {
if ( private.hasOwnProperty( prop ) ) {
return private[ prop ];
}
}
}
};
然后实例化一个新对象:
var course = new Course('Programming with JavaScript', 'A');
并开始使用所有私人数据:
course.get('name');
当然,您可能希望setter也能操纵这些数据;)
答案 2 :(得分:0)
您描述的代码执行以下操作:
// Declares a memory variable called course and stores and object in it
var course = new Object();
// Declares three variables
var name;
var gradingareas;
var finalgrade;
这些声明的变量不会自动连接到对象。如果要在对象上声明这些属性,则有两个选项:
示例1:将它们声明为对象的属性:
// Declares a memory variable called course and stores and object in it
var course = new Object();
// Access or create new properties with . or [] operator
course.name = 'math';
course.gradingareas = 'muliple';
course['finalgrade'] = 'A'
console.log(course);
示例2:在原型上声明它们:
// Create a constructor function
function Course (name, grade) {
this.name = name;
this.grade = grade;
}
// course is added on the prototype
Course.prototype.gradingareas = 'some gradingareas';
// the name and the grade are added on the object itself
var course = new Course ('willem', 10);
console.log(course);
答案 3 :(得分:0)
要使用构造函数和默认值创建一个非常简单的对象,您可以执行以下示例:
//My object with constructor
var myObjectWithConstrutorFunction = {
//construtor function with default values in constructor
myConstrutor: function(Name = 'bob', Age = 18){
this.Name = name;
this.Age = age;
}
};
// instance
var myInstance = new myObjectWithConstrutorFunction.myConstrutor();
// show on console
console.log('object with constructor function: ', myInstance);
// show properties
console.log(myInstace.Name, myInstance.Age);
PS:如果您要创建外部类,最好创建一个构造函数名称与类的同名。