IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Angular Discussion :

[Angular 4] Transmettre un attribut dans un autre composant ?


Sujet :

Angular

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut [Angular 4] Transmettre un attribut dans un autre composant ?
    Bonjour,

    je souhaite transmettre lors d'un clique d'un menu une valeur d'attribut dans un composant enfant.

    voici ma structure angular:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    app.componement.ts => contact.componement.ts
    dans le décorateur contact.componement.html j'ai mis le formulaire de contact:

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <form class="ui form contact" [class.cacher]="isHideContact">

    isHideContact à true, le formulaire est caché à false le fomulaire est présent:

    Code css : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    .cacher{
        display:none;
    }

    voici mon contact.componment.ts

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    import { Component, OnInit,Input } from '@angular/core';
     
    @Component({
      selector: 'app-contact',
      templateUrl: './contact.component.html',
      styleUrls: ['./contact.component.css']
    })
     
    export class ContactComponent implements OnInit {
     
     
     
    isHideContact = true; //à false  formulaire de contact apparaît
      constructor() { }
     
      ngOnInit() {
      }
     
      afficheContact(){
         this.isHideContact= false; //affiche le formulaire de contact dès qu'on clique sur contact
      }
    }
    Jusqu'a là cela fonctionne assez bien, dans le composant parent j'ai mis un lien "contact" à cliquer,
    je souhaite que si je clique dessus, l'attribut isHideContact soit initialisé à false

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <li class="column" (click)=afficheContact()>Contactez-moi</li>

    l'attribut idHideContact n'est accéssible qu'en local, comment s'y prendre pour initialiser cette attribut pour afficher mon formulaire ?

    merci de vos réponses

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2017
    Messages
    81
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2017
    Messages : 81
    Par défaut
    Tu dois utiliser l'attribut @Input dans ton composant enfant et le transmettre depuis ton composant parent
    Dans ton cas, tu peux utiliser @Input pour ta variable isHideContact

    Je peux te rediriger vers un article qui explique en détails comment cela fonctionne : ici

  3. #3
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    merci du tuto j'ai pu transmettre mon input et output à travers les composantes.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Débutant] accès à un attribut dans une autre méthode de la même classe
    Par zied_m dans le forum VB.NET
    Réponses: 4
    Dernier message: 28/07/2017, 13h21
  2. [DOM] Créer des attributs dans un autre namespace
    Par tchize_ dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 19/09/2013, 12h08
  3. Réponses: 2
    Dernier message: 21/08/2010, 18h08
  4. Réponses: 2
    Dernier message: 30/10/2008, 18h37
  5. Réponses: 3
    Dernier message: 30/11/2006, 06h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo