Javascript ist keine streng objektorientierte Sprache, sondern eine clientseitige Skriptsprache, die auf objektgesteuerter und ereignisgesteuerter Programmierung basiert. Grund: Objektorientiert umfasst drei Hauptfunktionen: Kapselung, Vererbung und Polymorphismus, während JavaScript nur über Kapselung verfügt und Vererbung nur Vererbung simuliert, nicht objektorientiert.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, JavaScript-Version 1.8.5, Dell G3-Computer.
Javascript ist keine objektorientierte Sprache im engeren Sinne, sondern eine clientseitige Skriptsprache, die auf objektgesteuerter, ereignisgesteuerter Programmierung basiert und nicht nur Objekte erstellen, sondern auch vorhandene Objekte verwenden kann.
Warum ist JavaScript keine objektorientierte Sprache?
Weil objektorientiert drei Hauptfunktionen umfasst: Kapselung, Vererbung und Polymorphismus. Es gibt nur eine Kapselung in JavaScript, und die Vererbung ist nur eine simulierte Vererbung, nicht objektorientiert.
Alles in allem ist in JavaScript alles ein Objekt, Eigenschaften, Arrays, Funktionen usw. sind alles Objekte.
Es gibt keine Überladung in JavaScript
Es gibt keine Überladung in JavaScript, die später definiert wird, und nur die letzte wird immer aufgerufen, und zwar die formale Parameter in JS sind nur Platzhalter, es sind zwei formale Parameter definiert und es kann nur ein Parameter übergeben werden. Dies dient nur der Bequemlichkeit des Programmierers.
Wenn formale Parameter nicht geschrieben werden, können Platzhalter nicht bequem für tatsächliche Parameter verwendet werden. In diesem Fall werden implizite formale Parameter arguments[0] verwendet, um auf den ersten tatsächlichen Parameter zuzugreifen, arguments[1] wird verwendet, um auf den zweiten tatsächlichen Parameter zuzugreifen , und so weiter.
Funktionen zum Simulieren von Klassen verwenden
Im Allgemeinen wird der erste Buchstabe des Klassennamens großgeschrieben. 1. Bei der Definition der Klasse gibt es einen Konstruktor. 2. Der Attributwert der Methode ist eine Funktion.
Beispiel:
<script type="text/javascript"> function Student (sno,sname,age) { this.sno = sno; this.sname = sname; this.age = age; this.study = function(){ alert('我是'+this.sname+',我在学习') } } var stu = new Student(1,'xiaoming',20); stu.study(); </script>
Verwenden Sie die Object-Klasse, um sofortige Objekte zu erstellen delete stu.name;//可以删除属性
<script type="text/javascript"> var stu = new Object(); stu.sno = 1; stu.sname = 'xiaoming'; stu.age = 20; stu.study = function(){ alert('我是'+this.sname+',我在学习'); } stu.study(); </script>
3. Verwenden Sie den Prototyp-Prototyp, um die Vererbung zu simulieren
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script type="text/javascript"> function Person (name,age) { this.name = name; this.age = age; this.eat = function(){ alert('姓名:'+this.name+",年龄:"+this.age+",我在吃饭"); } } function Student(sno,name,age){ Person.call(this,name,age);//相当于super(name,age) this.sno = sno; this.study = function(){ alert('学号:'+this.sno+',姓名:'+this.name+",年龄"+this.age+",我在学习"); } } var stu = new Student(1,'xiaoming',22); stu.eat(); stu.study(); </script> </head> <body> </body> </html>
Über das Prototypattribut einer Klasse können Sie wissen, welche Attribute und Methoden die Klasse hat. Das obige ist der detaillierte Inhalt vonIst Javascript objektorientiert?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
function Person (name,age) {
this.name = name;
this.age = age;
this.eat = function(){
alert('姓名:'+this.name+",年龄:"+this.age+",我在吃饭");
}
}
function Student(sno,name,age){
Person.apply(this,[name,age]);//相当于super(name,age)
this.sno = sno;
this.study = function(){
alert('学号:'+this.sno+',姓名:'+this.name+",年龄"+this.age+",我在学习");
}
}
var stu = new Student(1,'xiaoming',22);
stu.eat();
stu.study();
</script>
</head>
<body>
</body>
</html>