recherche
Maisondéveloppement back-endtutoriel phpCréez un site Web simple avec angulaire4 et nodejs-express

Cet article explique principalement comment créer les pages de connexion et d'enregistrement frontales et implémenter le routage angulaire.
Afin de faciliter la compréhension de tous, j'ai simplement dessiné un schéma d'analyse de routage de mon programme :

Créez un site Web simple avec angulaire4 et nodejs-express

Créer la page initiale et Définir l'itinéraire total

Le code de la page initiale app.component.html est le suivant :

<p>
  </p><p>
    </p><p>
      </p><h1 id="title">{{title}}</h1>
      <p>{{lead}}</p>
      <hr>
      <p>{{content}}
      </p>
    
  
  <router-outlet></router-outlet>

Il est composé d'un composant bootstrap jumbotron et d'une prise routeur. title dans Jumbotron, le lead et le contenu devraient changer à mesure que vous naviguez vers différentes pages, j'ai donc remplacé le contenu de ces trois balises par les expressions d'interpolation title, lead et content respectivement. Pour ce faire, j'ai créé un fournisseur de services JumbotronServive qui implémente le transfert de messages via rxjs. Le code de JumbotronServive est le suivant :

import { Injectable } from '@angular/core';
import { Subject } from 'rxjs/Subject';
export class Jumbotron{
    constructor(
        public title:string,
        public lead:string,
        public content:string
    ){}
}
@Injectable()
export class JumbotronServive{
    private jumbSource = new Subject<jumbotron>();
    jumb$ = this.jumbSource.asObservable();
    setJumbotron(jumb: Jumbotron){
        this.jumbSource.next(jumb);
    }  
}</jumbotron>

Créez d'abord une classe Jumbotron, qui contient 3 attributs titre, lead et contenu correspondant respectivement au titre, au lead et au contenu dans jumbotron, puis écrivez un classe de fournisseur de services, dans Cette classe déclare un objet Sujet rxjs (le Sujet est un Observable spécial qui permet aux valeurs d'être multidiffusées vers plusieurs observateurs), puis appelle asObservable() du Sujet pour déclarer un objet Observable jumb$ pour s'abonner aux messages envoyé par le Sujet. Enfin, déclarez un setJumbotron pour envoyer l'objet Jumbotron modifié. Dans la classe AppComponent, nous pouvons nous abonner et modifier le titre, le lead et le contenu du jumbotron. Le code est le suivant :

jumServ.jumb$.subscribe(
      jumb=>{
        this.title = jumb.title;
        this.lead = jumb.lead;
        this.content = jumb.content;
      });

router-outlet : sortie de routage, utilisée pour marquer l'endroit où la vue doit être affichée, ce qui signifie que toutes les vues d'itinéraire vers lesquelles vous naviguez seront affichées dans la balise <router-outlet></router-outlet>.
angular-cli (ci-après dénommé ng) a déjà écrit pour nous l'AppModule de base (le module racine du programme Angular, Angular démarre l'application en démarrant le module racine), jetons un œil ici :

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
import { AppComponent } from './app.component';
@NgModule({
  declarations: [
    AppComponent,
  ],
  imports: [
    BrowserModule,
    NgbModule.forRoot(),
    AppRoutingModule
  ],
  providers: [
    JumbotronServive,
  ],
  bootstrap: [AppComponent]
})
export class AppModule { }

Le décorateur @NgModule marque AppModule comme une classe de module angulaire (également appelée classe NgModule). @NgModule accepte un objet de métadonnées qui indique à Angular comment compiler et démarrer l'application.
@NgModule a les attributs suivants :

  • imports — le modèle de composant déclaré dans ce module nécessite des classes dans d'autres modules, dont le plus important est BrowserModule, qui est utilisé dans chaque navigateur Il est nécessaire pour exécuter des applications sur le serveur.

  • declarations — déclare les classes de vue appartenant à ce module et définit le seul composant de l'application, AppComponent, dans AppModule.

  • bootstrap — Composant racine, Angular le crée et l'insère dans la page hôte index.html.

  • fournisseurs - le créateur du service et ajouté à la liste globale des services, qui peuvent être utilisés dans n'importe quelle partie de l'application. JumbotronServive est ajouté ici pour fournir le titre et le lead dans le jumbotron. composant de bootstrap., mise à jour du contenu.

AppRoutingModule est le module de routage de l'application. Le code spécifique :

import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { PageNotFoundComponent } from './page-not-found.component';
const appRoutes: Routes = [
    {
        path:'',
        redirectTo:'/users',
        pathMatch:'full'
    },
    {path: '**', component: PageNotFoundComponent}
];
@NgModule({
    imports: [
        RouterModule.forRoot(appRoutes)
    ],
    exports:[
        RouterModule
    ]
})
export class AppRoutingModule{}

Définissez d'abord un tableau de routage, où les objets de routage incluent le chemin de routage (path). , et le routage Composant correspondant (composant), car notre site Web entre dans l'interface de gestion des utilisateurs dès son ouverture. Lors de la navigation vers la page d'accueil, il doit accéder directement à l'itinéraire de la page d'accueil (''). un composant correspondant, mais passe directement à la route des utilisateurs. Le but de la route path:'**' est d'accéder au composant PageNotFoundComponent lorsqu'aucune route n'est trouvée.
Après avoir défini le tableau de routes, importez RouterModule avec le décorateur @NgModule et transmettez le tableau de routes au tableau forRoot de RouterModule.
Enfin, exportez le module RouterModule.

Recommandations associées :

Opérations de préparation de projet et de création d'environnement dans Angular4
Explication détaillée d'exemples de classe de routeur de routage dans Angular4

Utilisez PHP et HTML pour écrire un projet d'enregistrement de connexion à un site Web simple Site Web html Connexion à un site Web personnel Code de connexion utilisateur html


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
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
Quelles données peuvent être stockées dans une session PHP?Quelles données peuvent être stockées dans une session PHP?May 02, 2025 am 12:17 AM

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

Comment démarrez-vous une session PHP?Comment démarrez-vous une session PHP?May 02, 2025 am 12:16 AM

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

Qu'est-ce que la régénération des sessions et comment améliore-t-elle la sécurité?Qu'est-ce que la régénération des sessions et comment améliore-t-elle la sécurité?May 02, 2025 am 12:15 AM

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.

Quelles sont les considérations de performances lors de l'utilisation de sessions PHP?Quelles sont les considérations de performances lors de l'utilisation de sessions PHP?May 02, 2025 am 12:11 AM

Les séances PHP ont un impact significatif sur les performances des applications. Les méthodes d'optimisation incluent: 1. Utilisez une base de données pour stocker les données de session pour améliorer la vitesse de réponse; 2. Réduire l'utilisation des données de session et stocker uniquement les informations nécessaires; 3. Utilisez un processeur de session non bloquant pour améliorer les capacités de concurrence; 4. Ajustez le temps d'expiration de la session pour équilibrer l'expérience utilisateur et la charge du serveur; 5. Utilisez des séances persistantes pour réduire le nombre de données de lecture et d'écriture.

En quoi les séances PHP diffèrent-elles des cookies?En quoi les séances PHP diffèrent-elles des cookies?May 02, 2025 am 12:03 AM

PhpsessionsareServer-côté, whileCookiesareclient-Side.1) SessionStoredataontheServer, aremoresecure, ethandleLargerData.2) CookiesstoredataontheClient, ArelessSecure, andlimitedIzeSize.USESESSIONSFORSENSEDATAANDCOOKIESFORNONNORNE-SENSENSITION, Client-Sidedata.

Comment PHP identifie-t-il la session d'un utilisateur?Comment PHP identifie-t-il la session d'un utilisateur?May 01, 2025 am 12:23 AM

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

Quelles sont les meilleures pratiques pour sécuriser les séances PHP?Quelles sont les meilleures pratiques pour sécuriser les séances PHP?May 01, 2025 am 12:22 AM

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

Où les fichiers de session PHP sont-ils stockés par défaut?Où les fichiers de session PHP sont-ils stockés par défaut?May 01, 2025 am 12:15 AM

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit

See all articles

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 Mac

SublimeText3 version Mac

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

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel