Maison interface Web js tutoriel JavaScript之自定义类型_javascript技巧

JavaScript之自定义类型_javascript技巧

May 16, 2016 pm 05:53 PM
自定义类型

1、直接创建模式。这是最简单也是最直接的一种模式,首先创建一个引用类型的对象,然后为其添加自定义属性和方法。示例代码如下:

复制代码 代码如下:

var person = new Object();
person.name = "Sam";
person.age = 16;
person.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
person.speak();

可以看到,上面创建了一个Object类型的对象,然后为其添加了name和age属性以及一个speak方法。直接创建模式虽然简单,但其缺点是显而易见的:当我们需要创建许多相同的对象时,每次都要重复编写代码。为了解决这个问题,我们可以将创建对象的过程进行封装,于是便有了下面的工厂模式。
2、工厂模式。工厂模式是程序设计中一种常用的设计模式,它主要是将创建对象的过程进行了封装,示例代码如下:

复制代码 代码如下:

function createPerson(name, age){
var person = new Object();
person.name = name;
person.age = age;
person.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
return person;
}
var person1 = createPerson("Sam", 16);
var person2 = createPerson("Jack", 18);

使用工厂模式后,创建相同类型的对象变得简单了。但工厂模式没有解决对象识别的问题,即我们无法确定创建的对象的具体类型。有过面向对象编程经验的开发人员都知道,对象的创建应当基于类,有了具体的自定义类,再来创建该类的对象。幸好,在JavaScript中,我们可以通过构造函数模式来模拟一个类。
3、构造函数模式。构造函数和普通函数没有任何区别。任何普通函数都可以作为构造函数,只要使用new操作符即可;任何构造函数也都可以作为普通函数来调用。只不过在JavaScript中,有一个约定,就是用作构造函数的函数名需要首字母大写。示例代码如下:

复制代码 代码如下:

function Person(name, age){
this.name = name;
this.age = age;
this.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
}
var person1 = new Person("Sam", 16);
var person2 = new Person("Jack", 18);

可以看到,在构造函数内部,我们使用了this来添加属性和方法,那么,这个this是指什么呢?当我们创建了一个Person的对象时,this即是指这个创建的对象。现在,我们可以识别出对象person1和person2的具体类型了。使用alert(person1 instanceOf Person)后可以发现,输出的值为true。但构造函数模式也有自己的缺点,就是构造函数内声明的方法在每次创建新对象时都会重新创建(在JavaScript中,函数也是对象)。也就是说,构造函数内的方法是与对象绑定的,而不是与类绑定的。下面代码的输出可以验证我们的推断。
alert(person1.speak == person2.speak); // false 解决这个缺点的一种比较简单的方法就是将函数的声明放到构造函数的外面,即:

复制代码 代码如下:

function Person(name, age){
this.name = name;
this.age = age;
this.speak = speak;
}
function speak(){
alert(this.name + "is " + this.age + "years old");
}
var person1 = new Person("Sam", 16);
var person2 = new Person("Jack", 18);
alert(person1.speak == person2.speak); // true

问题解决了,但这种方法又带来了新的问题。首先,函数speak是在全局作用域中声明的,但它却只能被用于Person构造函数,放在全局作用域中有被误用的风险;其次,如果一个自定义类型有很多的方法,则需要声明很多的全局函数,这既将导致全局作用域的污染,也不利于代码的封装。那么,有没有什么办法能让自定义类型的方法成为与类绑定的,又不污染全局作用域呢?答案是使用原型模式。
4、原型模式。在我们声明一个新的函数后,该函数(在JavaScript中,函数也是对象)就会拥有一个prototype的属性。prototype是一个对象,表示会被该函数创建的所有对象拥有的公共属性和方法。示例代码如下:

复制代码 代码如下:

function Person(){}
Person.prototype.name="Sam";
Person.prototype.age=16;
Person.prototype.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
var person1 = new Person();
person1.speak();
var person2 = new Person();
alert(person1.speak == person2.speak); // true


可以看到,虽然构造函数内没有声明speak方法,但我们创建的对象person1还是能调用speak方法,这是因为JavaScript有一个搜索规则,先搜索实例属性和方法,找到则返回;如果没找到,则再到prototype中去搜索。原型模式使得方法是与类相关的,并且没有污染全局作用域,但其也有自身的缺点:一是所有属性也都与类相关,这意味着所有对象共享一份属性,这显然是不合理的;二是没有办法向构造函数传入初始化数据了。解决的方法很简单,就是混合使用构造函数模式和原型模式。
5、组合模式。示例代码如下:

复制代码 代码如下:

function Person(name, age){
this.name = name;
this.age = age;
}
Person.prototype.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
var person1 = new Person();
person1.speak();
var person2 = new Person();
alert(person1.speak == person2.speak); // true

不难发现,组合模式实现了我们的所有需求,这也是目前应用得比较广泛的一种模式。有面向对象编程经验的开发人员可能会觉得将prototype的声明放在构造函数外面有点别扭,那么能否将其放到构造函数里去呢?答案是肯定的,使用动态组合模式即可。
6、动态组合模式。其原理就是先判断原型中的某个属性或方法是不是已经声明过,如果没有声明,则声明整个原型;否则,什么也不用做。示例代码如下:

复制代码 代码如下:

function Person(name, age){
this.name = name;
this.age = age;
if (Person.prototype.speak == "undefined"){
Person.prototype.speak = function(){
alert(this.name + "is " + this.age + "years old");
}
}
}
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelles sont les exigences pour que les fonctions C++ renvoient des types personnalisés ? Quelles sont les exigences pour que les fonctions C++ renvoient des types personnalisés ? Apr 19, 2024 pm 03:33 PM

Les fonctions C++ peuvent renvoyer des types personnalisés qui répondent aux exigences suivantes : Le type est entièrement défini. Constructeur par défaut. Les types valeur nécessitent des constructeurs de copie.

Comment définir et utiliser des types personnalisés à l'aide du langage Go ? Comment définir et utiliser des types personnalisés à l'aide du langage Go ? Jun 05, 2024 pm 12:41 PM

Dans Go, les types personnalisés peuvent être définis à l'aide du mot-clé type (struct) et contenir des champs nommés. Ils sont accessibles via des opérateurs d'accès aux champs et peuvent être associés à des méthodes pour manipuler l'état de l'instance. Dans les applications pratiques, les types personnalisés sont utilisés pour organiser des données complexes et simplifier les opérations. Par exemple, le système de gestion des étudiants utilise le type personnalisé Étudiant pour stocker les informations sur les étudiants et fournir des méthodes de calcul des notes moyennes et des taux de fréquentation.

Comment comparer les valeurs des types personnalisés dans Golang ? Comment comparer les valeurs des types personnalisés dans Golang ? Jun 05, 2024 pm 01:04 PM

Dans Golang, les valeurs des types personnalisés peuvent être comparées en utilisant directement l'opérateur == pour les types avec la même représentation sous-jacente. Pour les types plus complexes, utilisez la fonction reflex.DeepEqual pour comparer de manière récursive l’intégralité du contenu de deux valeurs.

Comment créer des types personnalisés immuables dans Golang ? Comment créer des types personnalisés immuables dans Golang ? Jun 02, 2024 am 09:41 AM

Oui, la création de types personnalisés immuables dans Go offre de nombreux avantages, notamment la sécurité des threads, la facilité de raisonnement et une gestion des erreurs plus efficace. Pour créer un type immuable, vous devez suivre les étapes suivantes : Définir le type : Déclarez un type personnalisé qui contient des variables membres et ne doit pas inclure de pointeurs. Déclarez l'immuabilité : assurez-vous que toutes les variables membres sont des types de base ou d'autres types immuables et évitez d'utiliser des tranches, des cartes ou des pointeurs. Utiliser des méthodes de récepteur de valeur : utilisez des récepteurs de valeur pour les méthodes associées à un type, interdisant l'allocation littérale de structure et forçant les méthodes à fonctionner uniquement sur elles-mêmes.

Comment sérialiser les types personnalisés lors de l'utilisation de Golang ? Comment sérialiser les types personnalisés lors de l'utilisation de Golang ? Jun 03, 2024 pm 05:07 PM

Dans Go, les méthodes de sérialisation des types personnalisés sont les suivantes : implémentation de l'interface json.Marshaler lors de l'utilisation de la sérialisation JSON et implémentation des interfaces GobEncoder et GobDecoder dans le package encoding/gob lors de l'utilisation de la sérialisation Gob.

Comment surcharger les opérateurs pour les types personnalisés dans Golang ? Comment surcharger les opérateurs pour les types personnalisés dans Golang ? Jun 02, 2024 am 09:26 AM

Dans Go, vous pouvez personnaliser les types en surchargeant les opérateurs en créant une méthode avec le même nom pour le type, en recevant une autre instance de type et en renvoyant le même type de résultat. De cette façon, les opérateurs personnalisés peuvent être utilisés tout comme les opérateurs intégrés, facilitant ainsi l'utilisation et la lisibilité du code.

Comment implémenter des types personnalisés dans Go ? Comment implémenter des types personnalisés dans Go ? May 10, 2023 pm 03:34 PM

Go est un langage de programmation orienté objet et typé statiquement, permettant ainsi aux développeurs de simplifier le code et d'améliorer la lisibilité grâce à des types personnalisés. Dans cet article, nous explorerons comment implémenter des types personnalisés dans Go afin que les développeurs puissent mieux profiter de cette fonctionnalité. Structures Une structure dans Go est un type personnalisé qui permet aux développeurs d'implémenter des structures de données plus complexes en combinant des variables de différents types. Voici un exemple de struct : typePersonstruct{name

Une plongée approfondie dans les méthodes de type personnalisées dans le langage Go Une plongée approfondie dans les méthodes de type personnalisées dans le langage Go Mar 24, 2024 am 09:45 AM

Exploration approfondie des méthodes de type personnalisé dans le langage Go Dans le langage Go, nous pouvons ajouter des méthodes aux types personnalisés pour étendre les fonctionnalités du type personnalisé. En définissant des méthodes sur les types, nous pouvons implémenter les caractéristiques de la programmation orientée objet et rendre le code plus modulaire et maintenable. Cet article approfondira l'utilisation de méthodes de type personnalisées dans le langage Go et fournira des exemples de code spécifiques. 1. Qu'est-ce qu'une méthode de type personnalisée ? Dans le langage Go, nous pouvons implémenter des méthodes de type personnalisées en définissant des méthodes sur la structure. Ces méthodes peuvent

See all articles