Maison interface Web js tutoriel Exemple de code pour les interactions entre les composants angulaires

Exemple de code pour les interactions entre les composants angulaires

May 29, 2018 am 10:07 AM
angular 交互 示例

Cet article présente principalement l'exemple de code pour l'interaction entre les composants angulaires. Selon la direction du transfert de données, il est divisé en trois méthodes d'interaction : composant parent vers composant enfant, composant enfant vers composant parent et prestation de services. Il a une grande valeur pratique. Les amis qui en ont besoin peuvent s'y référer

Dans le développement d'applications angulaires, on peut dire que les composants sont partout. Cet article présentera plusieurs scénarios de communication de composants courants, qui sont des méthodes d'interaction entre deux ou plusieurs composants.

Selon le sens de transmission des données, il est divisé en trois méthodes d'interaction : composant parent à composant enfant, composant enfant à composant parent et prestation de services.

Le composant parent transmet

le composant enfant définit l'attribut d'entrée via le décorateur @Input, puis le composant parent Lors du référencement d'un sous-composant, les données sont transmises au sous-composant via ces propriétés d'entrée. Le sous-composant peut intercepter les modifications des valeurs des propriétés d'entrée via setter ou ngOnChanges().

Définissez d'abord deux composants, à savoir le sous-composant DemoChildComponent et le composant parent DemoParentComponent.

Composant enfant :

@Component({
 selector: 'demo-child',
 template: `
 <p>{{paramOne}}</p>
 <p>{{paramTwo}}</p>
 `
})
export class DemoChildComponent {
 @Input() paramOne: any; // 输入属性1
 @Input() paramTwo: any; // 输入属性2
}
Copier après la connexion

Le sous-composant définit les attributs d'entrée paramOne et paramTwo via @Input() (la valeur de l'attribut peut être n'importe quel type de données)

Composant parent :

@Component({
 selector: &#39;demo-parent&#39;,
 template: `
 <demo-child [paramOne]=&#39;paramOneVal&#39; [paramTwo]=&#39;paramTwoVal&#39;></demo-child>
 `
})
export class DemoParentComponent {
 paramOneVal: any = &#39;传递给paramOne的数据&#39;;
 paramTwoVal: any = &#39;传递给paramTwo的数据&#39;;
}
Copier après la connexion

Le composant parent fait référence au composant enfant DemoChildComponent via le sélecteur demo-child dans son modèle et transmet les données au composant enfant via les deux entrées les propriétés paramOne et paramTwo du composant enfant, et enfin les deux lignes de texte, les données passées à paramOne et les données passées à paramTwo, sont affichées dans le modèle du sous-composant.

Interception des modifications dans les valeurs d'attribut d'entrée via des setters

Dans les applications pratiques, nous avons souvent besoin de détecter des modifications dans une valeur d'attribut d'entrée . Lorsque nous effectuons l'opération correspondante, nous devons à ce moment utiliser le setter de l'attribut d'entrée pour intercepter les modifications de la valeur de l'attribut d'entrée.

On transforme le sous-composant DemoChildComponent comme suit :

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <p>{{paramOneVal}}</p>
 <p>{{paramTwo}}</p>
 `
})
export class DemoChildComponent {
 private paramOneVal: any;
 
 @Input() 
 set paramOne (val: any) { // 输入属性1
  this.paramOneVal = val;
  // dosomething
 };
 get paramOne () {
  return this.paramOneVal;
 };
 
 @Input() paramTwo: any; // 输入属性2
}
Copier après la connexion

Dans le code ci-dessus, on peut Vous pouvez voir que la valeur interceptée val est affectée à la propriété privée interne paramOneVal via le setter de l'attribut paramOne, obtenant ainsi l'effet du composant parent transmettant des données au composant enfant. Bien sûr, le plus important est que vous puissiez effectuer davantage d'autres opérations dans le setter, ce qui rend le programme plus flexible.

Utilisez ngOnChanges() pour intercepter les modifications des valeurs des attributs d'entrée

La méthode d'interception des modifications des valeurs des attributs d'entrée via setter ne peut être utilisé pour surveiller les modifications d’une seule valeur d’attribut. Si vous devez surveiller plusieurs attributs d’entrée interactifs, cette méthode devient insuffisante. En utilisant la méthode ngOnChanges() de l'interface hook de cycle de vie OnChanges (appelée lorsque la valeur des variables explicitement spécifiées par le composant via le décorateur @Input change), vous pouvez surveiller simultanément les modifications des valeurs de plusieurs propriétés d'entrée.

Ajouter ngOnChanges dans le sous-composant DemoChildComponent :

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <p>{{paramOneVal}}</p>
 <p>{{paramTwo}}</p>
 `
})
export class DemoChildComponent implements OnChanges {
 private paramOneVal: any;
 
 @Input() 
 set paramOne (val: any) { // 输入属性1
  this.paramOneVal = val;
  // dosomething
 };
 get paramOne () {
  return this.paramOneVal;
 };
 
 @Input() paramTwo: any; // 输入属性2
 
 ngOnChanges(changes: {[propKey: string]: SimpleChange}) {
  for (let propName in changes) { // 遍历changes
   let changedProp = changes[propName]; // propName是输入属性的变量名称
   let to = JSON.stringify(changedProp.currentValue); // 获取输入属性当前值
   if (changedProp.isFirstChange()) { // 判断输入属性是否首次变化
    console.log(`Initial value of ${propName} set to ${to}`);
   } else {
    let from = JSON.stringify(changedProp.previousValue); // 获取输入属性先前值
    console.log(`${propName} changed from ${from} to ${to}`);
   }
  }
 }
}
Copier après la connexion

Modifications de paramètres reçues par la nouvelle méthode ngOnChanges Il s'agit d'un objet avec le nom de l'attribut d'entrée comme clé et la valeur comme SimpleChange. L'objet SimpleChange contient des attributs tels que si l'attribut d'entrée actuel change pour la première fois, la valeur précédente et la valeur actuelle. Par conséquent, dans la méthode ngOnChanges, plusieurs valeurs d'attribut d'entrée peuvent être surveillées et les opérations correspondantes effectuées en parcourant l'objet changes.

Obtenir l'instance du composant parent

L'introduction précédente est que le composant enfant définit l'attribut d'entrée via le décorateur @Input, de sorte que le Le composant parent peut transmettre les données de transmission des propriétés d'entrée aux composants enfants.

Bien sûr, nous pouvons penser à une méthode plus proactive, qui consiste à obtenir l'instance du composant parent puis à appeler une propriété ou une méthode du composant parent pour obtenir les données requises. Étant donné que chaque instance de composant est ajoutée au conteneur de l'injecteur, l'instance du composant parent peut être trouvée via l'injection de dépendances.

Il est plus difficile pour le composant enfant d'obtenir l'instance du composant parent que pour le composant parent d'obtenir l'instance du composant enfant (obtenue directement via les variables de modèle, @ViewChild ou @ViewChildren).

Pour récupérer l'instance du composant parent dans le composant enfant, il existe deux situations :

Le type du composant parent est connu

Dans ce cas, vous pouvez obtenir directement le type connu de référence du composant parent en injectant DemoParentComponent dans le constructeur. L'exemple de code est le suivant :

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <p>{{paramOne}}</p>
 <p>{{paramTwo}}</p>
 `
})
export class DemoChildComponent {
 paramOne: any;
 paramTwo: any;

 constructor(public demoParent: DemoParentComponent) {

  // 通过父组件实例demoParent获取数据
  this.paramOne = demoParent.paramOneVal;
  this.paramTwo = demoParent.paramTwoVal;
 }
}
Copier après la connexion

Type de composant parent inconnu

Un composant peut être un composant enfant de plusieurs composants. Parfois, il n'est pas possible de connaître directement le type de. le composant parent. Dans Angular, vous pouvez utiliser la méthode class —Interface (Class-Interface) pour rechercher, c'est-à-dire laisser le composant parent vous aider dans la recherche en fournissant un alias avec le même nom que l'identifiant de l'interface de classe.

Créez d'abord la classe abstraite DemoParent, qui déclare uniquement les attributs paramOneVal et paramTwoVal sans implémentation (affectation). L'exemple de code est le suivant :

export abstract class DemoParent {
 paramOneVal: any;
 paramTwoVal: any;
}
Copier après la connexion
<. 🎜>

Définissez ensuite un alias Provider dans les métadonnées des fournisseurs du composant parent DemoParentComponent, et utilisez useExisting pour injecter une instance du composant parent DemoParentComponent. L'exemple de code est le suivant :


<. 🎜>

@Component({
 selector: &#39;demo-parent&#39;,
 template: `
 <demo-child [paramOne]=&#39;paramOneVal&#39; [paramTwo]=&#39;paramTwoVal&#39;></demo-child>
 `,
 providers: [{provider: DemoParent, useExisting: DemoParentComponent}]
})
export class DemoParentComponent implements DemoParent {
 paramOneVal: any = &#39;传递给paramOne的数据&#39;;
 paramTwoVal: any = &#39;传递给paramTwo的数据&#39;;
}
Copier après la connexion

然后在子组件中就可通过DemoParent这个标识找到父组件的示例了,示例代码如下:

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <p>{{paramOne}}</p>
 <p>{{paramTwo}}</p>
 `
})
export class DemoChildComponent {
 paramOne: any;
 paramTwo: any;

 constructor(public demoParent: DemoParent) {

  // 通过父组件实例demoParent获取数据
  this.paramOne = demoParent.paramOneVal;
  this.paramTwo = demoParent.paramTwoVal;
 }
}
Copier après la connexion

子组件向父组件传递

依然先定义两个组件,分别为子组件DemoChildComponent和父组件DemoParentComponent.

子组件:

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <p>子组件DemoChildComponent</p>
 `
})
export class DemoChildComponent implements OnInit {
 readyInfo: string = &#39;子组件DemoChildComponent初始化完成!&#39;;
 @Output() ready: EventEmitter = new EventEmitter<any>(); // 输出属性
 
 ngOnInit() {
  this.ready.emit(this.readyInfo);
 }
}
Copier après la connexion

父组件:

@Component({
 selector: &#39;demo-parent&#39;,
 template: `
 <demo-child (ready)="onReady($event)" #demoChild></demo-child>
 <p>
  <!-- 通过本地变量获取readyInfo属性,显示:子组件DemoChildComponent初始化完成! -->
  readyInfo: {{demoChild.readyInfo}}
 </p>
 <p>
  <!-- 通过组件类获取子组件示例,然后获取readyInfo属性,显示:子组件DemoChildComponent初始化完成! -->
  readyInfo: {{demoChildComponent.readyInfo}}
 </p>
 `
})
export class DemoParentComponent implements AfterViewInit {
 // @ViewChild(&#39;demoChild&#39;) demoChildComponent: DemoChildComponent; // 通过模板别名获取
 @ViewChild(DemoChildComponent) demoChildComponent: DemoChildComponent; // 通过组件类型获取
 
 ngAfterViewInit() {
  console.log(this.demoChildComponent.readyInfo); // 打印结果:子组件DemoChildComponent初始化完成!
 }

 onReady(evt: any) {
  console.log(evt); // 打印结果:子组件DemoChildComponent初始化完成!
 }
}
Copier après la connexion

父组件监听子组件的事件

子组件暴露一个 EventEmitter 属性,当事件发生时,子组件利用该属性 emits(向上弹射)事件。父组件绑定到这个事件属性,并在事件发生时作出回应。

在上面定义好的子组件和父组件,我们可以看到:

子组件通过@Output()定义输出属性ready,然后在ngOnInit中利用ready属性的 emits(向上弹射)事件。

父组件在其模板中通过选择器demo-child引用子组件DemoChildComponent,并绑定了一个事件处理器(onReady()),用来响应子组件的事件($event)并打印出数据(onReady($event)中的$event是固定写法,框架(Angular)把事件参数(用 $event 表示)传给事件处理方法)。

父组件与子组件通过本地变量(模板变量)互动

父组件不能使用数据绑定来读取子组件的属性或调用子组件的方法。但可以在父组件模板里,新建一个本地变量来代表子组件,然后利用这个变量来读取子组件的属性和调用子组件的方法。

在上面定义好的子组件和父组件,我们可以看到:

父组件在模板demo-child标签上定义了一个demoChild本地变量,然后在模板中获取子组件的属性:

<p>
 <!-- 获取子组件的属性readyInfo,显示:子组件DemoChildComponent初始化完成! -->
 readyInfo: {{demoChild.readyInfo}}
</p>
Copier après la connexion

父组件调用@ViewChild()

本地变量方法是个简单便利的方法。但是它也有局限性,因为父组件-子组件的连接必须全部在父组件的模板中进行。父组件本身的代码对子组件没有访问权。

如果父组件的类需要读取子组件的属性值或调用子组件的方法,就不能使用本地变量方法。

当父组件类需要这种访问时,可以把子组件作为 ViewChild,注入到父组件里面。

在上面定义好的子组件和父组件,我们可以看到:

父组件在组件类中通过@ViewChild()获取到子组件的实例,然后就可以在模板或者组件类中通过该实例获取子组件的属性:

<p>
 <!-- 通过组件类获取子组件示例,然后获取readyInfo属性,显示:子组件DemoChildComponent初始化完成! -->
 readyInfo: {{demoChildComponent.readyInfo}}
</p>
Copier après la connexion

ngAfterViewInit() {
 console.log(this.demoChildComponent.readyInfo); // 打印结果:子组件DemoChildComponent初始化完成!
}
Copier après la connexion

通过服务传递

Angular的服务可以在模块注入或者组件注入(均通过providers注入)。

在模块中注入的服务在整个Angular应用都可以访问(除惰性加载的模块)。

在组件中注入的服务就只能该组件和其子组件进行访问,这个组件子树之外的组件将无法访问该服务或者与它们通讯。

下面的示例就以在组件中注入的服务来进行父子组件之间的数据传递:

通讯的服务:

@Injectable()
export class CallService {
 info: string = &#39;我是CallService的info&#39;;
}
Copier après la connexion

父组件:

@Component({
 selector: &#39;demo-parent&#39;,
 template: `
 <demo-child></demo-child>
 <button (click)="changeInfo()">父组件改变info</button>
 <p>
  <!-- 显示:我是CallService的info -->
  {{callService.info}}
 </p>
 `,
 providers: [CallService]
})
export class DemoParentComponent {
 constructor(public callService: CallService) {
  console.log(callService.info); // 打印结果:我是CallService的info
 }
 
 changeInfo() {
  this.callService.info = &#39;我是被父组件改变的CallService的info&#39;;
 }
}
Copier après la connexion

子组件:

@Component({
 selector: &#39;demo-child&#39;,
 template: `
 <button (click)="changeInfo()">子组件改变info</button>
 `
})
export class DemoChildComponent {
 constructor(public callService: CallService) {
  console.log(callService.info); // 打印结果:我是CallService的info
 }
 
 changeInfo() {
  this.callService.info = &#39;我是被子组件改变的CallService的info&#39;;
 }
}
Copier après la connexion

上面的代码中,我们定义了一个CallService服务,在其内定义了info属性,后面将分别在父子组件通过修改这个属性的值达到父子组件互相传递数据的目的。

然后通过DemoParentComponent的providers元数据数组提供CallService服务的实例,并通过构造函数分别注入到父子组件中。

此时,通过父组件改变info按钮或子组件改变info按钮在父组件或子组件中改变CallService服务的info属性值,然后在页面可看到改变之后对应的info属性值。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

jQuery实现文字超过1行、2行或规定的行数时自动加省略号的方法

vue渲染时闪烁{{}}的问题及解决方法

浅谈js获取ModelAndView值的问题

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment installer Angular sur Ubuntu 24.04 Comment installer Angular sur Ubuntu 24.04 Mar 23, 2024 pm 12:20 PM

Angular.js est une plateforme JavaScript librement accessible pour créer des applications dynamiques. Il vous permet d'exprimer rapidement et clairement divers aspects de votre application en étendant la syntaxe HTML en tant que langage de modèle. Angular.js fournit une gamme d'outils pour vous aider à écrire, mettre à jour et tester votre code. De plus, il offre de nombreuses fonctionnalités telles que le routage et la gestion des formulaires. Ce guide expliquera comment installer Angular sur Ubuntu24. Tout d’abord, vous devez installer Node.js. Node.js est un environnement d'exécution JavaScript basé sur le moteur ChromeV8 qui vous permet d'exécuter du code JavaScript côté serveur. Être à Ub

Introduction aux fonctions Python : Introduction et exemples de fonction exec Introduction aux fonctions Python : Introduction et exemples de fonction exec Nov 03, 2023 pm 02:09 PM

Introduction aux fonctions Python : Introduction et exemples de fonction exec Introduction : En Python, exec est une fonction intégrée utilisée pour exécuter du code Python stocké dans une chaîne ou un fichier. La fonction exec fournit un moyen d'exécuter dynamiquement du code, permettant au programme de générer, modifier et exécuter du code selon les besoins pendant l'exécution. Cet article explique comment utiliser la fonction exec et donne quelques exemples de code pratiques. Comment utiliser la fonction exec : La syntaxe de base de la fonction exec est la suivante : exec

Mar 22, 2024 pm 09:33 PM

Spécifications d'indentation et exemples du langage Go Le langage Go est un langage de programmation développé par Google. Il est connu pour sa syntaxe concise et claire, dans laquelle les spécifications d'indentation jouent un rôle crucial dans la lisibilité et la beauté du code. Cet article présentera les spécifications d'indentation du langage Go et les expliquera en détail à travers des exemples de code spécifiques. Spécifications d'indentation Dans le langage Go, les tabulations sont utilisées pour l'indentation au lieu des espaces. Chaque niveau d'indentation correspond à un onglet, généralement défini sur une largeur de 4 espaces. De telles spécifications unifient le style de codage et permettent aux équipes de travailler ensemble pour compiler

Activer le mode d'interaction en écran partagé dans Win11 Activer le mode d'interaction en écran partagé dans Win11 Dec 25, 2023 pm 03:05 PM

Dans le système Win11, nous pouvons permettre à plusieurs moniteurs d'utiliser le même système et de fonctionner ensemble en activant l'interaction sur écran partagé. Cependant, de nombreux amis ne savent pas comment activer l'interaction sur écran partagé. les paramètres du système. Ce qui suit est Levez-vous et étudiez. Comment ouvrir l'interaction en écran partagé dans Win11 1. Cliquez sur le menu Démarrer et recherchez "Paramètres" 2. Recherchez ensuite les paramètres "Système". 3. Après avoir saisi les paramètres système, sélectionnez « Affichage » à gauche. 4. Sélectionnez ensuite « Étendre ces affichages » dans les multiples affichages à droite.

Explication détaillée de la fonction Oracle DECODE et exemples d'utilisation Explication détaillée de la fonction Oracle DECODE et exemples d'utilisation Mar 08, 2024 pm 03:51 PM

La fonction DECODE dans Oracle est une expression conditionnelle souvent utilisée pour renvoyer différents résultats en fonction de différentes conditions dans les instructions de requête. Cet article présentera en détail la syntaxe, l'utilisation et un exemple de code de la fonction DECODE. 1. Syntaxe de la fonction DECODE DECODE(expr,search1,result1[,search2,result2,...,default]) expr : l'expression ou le champ à comparer. recherche1,

Introduction aux fonctions Python : utilisation et exemples de fonction abs Introduction aux fonctions Python : utilisation et exemples de fonction abs Nov 03, 2023 pm 12:05 PM

Introduction aux fonctions Python : utilisation et exemples de la fonction abs 1. Introduction à l'utilisation de la fonction abs En Python, la fonction abs est une fonction intégrée utilisée pour calculer la valeur absolue d'une valeur donnée. Il peut accepter un argument numérique et renvoyer la valeur absolue de ce nombre. La syntaxe de base de la fonction abs est la suivante : abs(x) où x est le paramètre numérique permettant de calculer la valeur absolue, qui peut être un nombre entier ou un nombre à virgule flottante. 2. Exemples de fonction abs Ci-dessous, nous montrerons l'utilisation de la fonction abs à travers quelques exemples spécifiques : Exemple 1 : Calcul

Composants angulaires et leurs propriétés d'affichage : comprendre les valeurs par défaut non bloquantes Composants angulaires et leurs propriétés d'affichage : comprendre les valeurs par défaut non bloquantes Mar 15, 2024 pm 04:51 PM

Le comportement d'affichage par défaut des composants du framework Angular ne concerne pas les éléments au niveau du bloc. Ce choix de conception favorise l'encapsulation des styles de composants et encourage les développeurs à définir consciemment la manière dont chaque composant est affiché. En définissant explicitement l'affichage des propriétés CSS, l'affichage des composants angulaires peut être entièrement contrôlé pour obtenir la mise en page et la réactivité souhaitées.

Compétences en développement Vue3+TS+Vite : comment interagir avec l'API backend Compétences en développement Vue3+TS+Vite : comment interagir avec l'API backend Sep 08, 2023 pm 06:01 PM

Compétences en développement Vue3+TS+Vite : Comment interagir avec l'API back-end Introduction : Dans le développement d'applications Web, l'interaction des données entre le front-end et le back-end est un lien très important. En tant que framework front-end populaire, Vue3 propose de nombreuses façons d'interagir avec les API back-end. Cet article expliquera comment utiliser l'environnement de développement Vue3+TypeScript+Vite pour interagir avec l'API back-end et approfondira la compréhension grâce à des exemples de code. 1. Utilisez Axios pour envoyer des requêtes.

See all articles