\n
    \n\n\n\n

    Aqui está a tradu??o para o inglês:<\/p>\n\n\n


    \n\n

    \n \n \n Setting Up the Routes\n<\/h2>\n\n

    Update the src\/App.php file to include the TodoList routes:
    \n<\/p>\n\n

    use App\\Http\\Controllers\\TodoController;\n\n$app = new \\Lithe\\App;\n\n\/\/ Route for the main page\n$app->get('\/', [TodoController::class, 'index']);\n\n\/\/ API routes\n$app->get('\/todos\/list', [TodoController::class, 'list']);\n$app->post('\/todos', [TodoController::class, 'store']);\n$app->put('\/todos\/:id', [TodoController::class, 'update']);\n$app->delete('\/todos\/:id', [TodoController::class, 'delete']);\n\n$app->listen();\n<\/pre>\n\n\n\n

    \n \n \n Exécution de l'application\n<\/h2>\n\n

    Pour démarrer le serveur de développement, exécutez?:
    \n<\/p>\n\n

    php line serve\n<\/pre>\n\n\n\n

    Accédez à http:\/\/localhost:8000 dans votre navigateur pour voir l'application en action.<\/p>\n\n

    \n \n \n Fonctionnalités implémentées\n<\/h2>\n\n

    Notre TodoList présente les fonctionnalités suivantes?:<\/p>\n\n

      \n
    1. Liste des taches par ordre chronologique inverse<\/li>\n
    2. Ajout de nouvelles taches<\/li>\n
    3. Marquer les taches comme terminées\/en attente<\/li>\n
    4. Supprimer des taches<\/li>\n
    5. Interface réactive et conviviale<\/li>\n
    6. Retour visuel pour toutes les actions<\/li>\n
    7. Gestion des erreurs<\/li>\n<\/ol>\n\n

      \n \n \n Conclusion\n<\/h2>\n\n

      Vous disposez désormais d'une application TodoList entièrement fonctionnelle construite avec Lithe. Cet exemple montre comment créer une application Web moderne avec PHP, notamment?:<\/p>\n\n

        \n
      • Structure appropriée du code MVC<\/li>\n
      • Implémentation de l'API RESTful<\/li>\n
      • Interface utilisateur interactive<\/li>\n
      • Intégration de base de données<\/li>\n
      • Gestion des erreurs<\/li>\n
      • Commentaires des utilisateurs<\/li>\n<\/ul>\n\n

        à partir de là, vous pouvez étendre l'application en ajoutant de nouvelles fonctionnalités telles que?:<\/p>\n\n

          \n
        • Authentification de l'utilisateur<\/li>\n
        • Catégorisation des taches<\/li>\n
        • Dates d'échéance<\/li>\n
        • Filtres et recherche<\/li>\n<\/ul>\n\n

          Pour continuer à en apprendre davantage sur Lithe, visitez le Linktree<\/strong>, où vous pouvez accéder au Discord, à la documentation et bien plus encore?!<\/p>\n\n\n \n\n \n "}

          亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

          Maison développement back-end tutoriel php Créer une TodoList avec PHP et le framework Lithe?: un guide complet

          Créer une TodoList avec PHP et le framework Lithe?: un guide complet

          Nov 24, 2024 am 04:10 AM

          Creating a TodoList with PHP and the Lithe Framework: A Complete Guide

          Dans ce tutoriel, nous allons créer une application TodoList fonctionnelle en utilisant Lithe. Vous apprendrez à structurer votre projet, à créer des vues interactives et à implémenter une API RESTful pour gérer vos taches. Ce projet servira d'excellent exemple de la fa?on de créer des applications Web modernes avec PHP.

          Conditions préalables

          • PHP 7.4 ou supérieur
          • Compositeur installé
          • MySQL
          • Connaissance de base de PHP et JavaScript

          Structure du projet

          Tout d'abord, créons un nouveau projet Lithe?:

          composer create-project lithephp/lithephp todo-app
          cd todo-app
          

          Configuration de la base de données

          Modifiez le fichier .env à la racine du projet avec la configuration suivante?:

          DB_CONNECTION_METHOD=mysqli
          DB_CONNECTION=mysql
          DB_HOST=localhost
          DB_NAME=lithe_todos
          DB_USERNAME=root
          DB_PASSWORD=
          DB_SHOULD_INITIATE=true
          

          Création de la migration

          Exécutez la commande pour créer une nouvelle migration?:

          php line make:migration CreateTodosTable
          

          Modifiez le fichier de migration généré dans src/database/migrations/?:

          return new class
          {
              public function up(mysqli $db): void
              {
                  $query = "
                      CREATE TABLE IF NOT EXISTS todos (
                          id INT(11) AUTO_INCREMENT PRIMARY KEY,
                          title VARCHAR(255) NOT NULL,
                          completed BOOLEAN DEFAULT FALSE,
                          created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
                          updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
                      )
                  ";
                  $db->query($query);
              }
          
              public function down(mysqli $db): void
              {
                  $query = "DROP TABLE IF EXISTS todos";
                  $db->query($query);
              }
          };
          

          Exécuter la migration?:

          php line migrate
          

          Implémentation du modèle

          Générer un nouveau modèle?:

          php line make:model Todo
          

          Modifiez le fichier src/models/Todo.php?:

          namespace App\Models;
          
          use Lithe\Database\Manager as DB;
          
          class Todo
          {
              public static function all(): array
              {
                  return DB::connection()
                      ->query("SELECT * FROM todos ORDER BY created_at DESC")
                      ->fetch_all(MYSQLI_ASSOC);
              }
          
              public static function create(array $data): ?array
              {
                  $stmt = DB::connection()->prepare(
                      "INSERT INTO todos (title, completed) VALUES (?, ?)"
                  );
                  $completed = false;
                  $stmt->bind_param('si', $data['title'], $completed);
                  $success = $stmt->execute();
          
                  if ($success) {
                      $id = $stmt->insert_id;
                      return [
                          'id' => $id,
                          'title' => $data['title'],
                          'completed' => $completed
                      ];
                  }
          
                  return null;
              }
          
              public static function update(int $id, array $data): bool
              {
                  $stmt = DB::connection()->prepare(
                      "UPDATE todos SET completed = ? WHERE id = ?"
                  );
                  $stmt->bind_param('ii', $data['completed'], $id);
                  return $stmt->execute();
              }
          
              public static function delete(int $id): bool
              {
                  $stmt = DB::connection()->prepare("DELETE FROM todos WHERE id = ?");
                  $stmt->bind_param('i', $id);
                  return $stmt->execute();
              }
          }
          

          Création du contr?leur

          Générer un nouveau contr?leur?:

          php line make:controller TodoController
          

          Modifiez le fichier src/http/controllers/TodoController.php?:

          namespace App\Http\Controllers;
          
          use App\Models\Todo;
          use Lithe\Http\Request;
          use Lithe\Http\Response;
          
          class TodoController
          {
              public static function index(Request $req, Response $res)
              {
                  return $res->view('todo.index');
              }
          
              public static function list(Request $req, Response $res)
              {
                  $todos = Todo::all();
                  return $res->json($todos);
              }
          
              public static function store(Request $req, Response $res)
              {
                  $data = (array) $req->body();
                  $todo = Todo::create($data);
                  $success = $todo ? true : false;
          
                  return $res->json([
                      'success' => $success,
                      'message' => $success ? 'Task created successfully' : 'Failed to create task',
                      'todo' => $todo
                  ]);
              }
          
              public static function update(Request $req, Response $res)
              {
                  $id = $req->param('id');
                  $data = (array) $req->body();
                  $success = Todo::update($id, $data);
          
                  return $res->json([
                      'success' => $success,
                      'message' => $success ? 'Task updated successfully' : 'Failed to update task'
                  ]);
              }
          
              public static function delete(Request $req, Response $res)
              {
                  $id = $req->param('id');
                  $success = Todo::delete($id);
          
                  return $res->json([
                      'success' => $success,
                      'message' => $success ? 'Task removed successfully' : 'Failed to remove task'
                  ]);
              }
          }
          

          Création des vues

          Créez le répertoire src/views/todo et ajoutez le fichier index.php?:

          <!DOCTYPE html>
          <html>
          <head>
              <title>TodoList with Lithe</title>
              <meta charset="UTF-8">
              <meta name="viewport" content="width=device-width, initial-scale=1.0">
              <style>
                  * {
                      margin: 0;
                      padding: 0;
                      box-sizing: border-box;
                      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
                  }
          
                  body {
                      min-height: 100vh;
                      background-color: #ffffff;
                      padding: 20px;
                  }
          
                  .container {
                      max-width: 680px;
                      margin: 0 auto;
                      padding: 40px 20px;
                  }
          
                  h1 {
                      color: #1d1d1f;
                      font-size: 34px;
                      font-weight: 700;
                      margin-bottom: 30px;
                  }
          
                  .todo-form {
                      display: flex;
                      gap: 12px;
                      margin-bottom: 30px;
                      border-bottom: 1px solid #e5e5e7;
                      padding-bottom: 30px;
                  }
          
                  .todo-input {
                      flex: 1;
                      padding: 12px 16px;
                      font-size: 17px;
                      border: 1px solid #e5e5e7;
                      border-radius: 10px;
                      background-color: #f5f5f7;
                      transition: all 0.2s;
                  }
          
                  .todo-input:focus {
                      outline: none;
                      background-color: #ffffff;
                      border-color: #0071e3;
                  }
          
                  .add-button {
                      padding: 12px 20px;
                      background: #0071e3;
                      color: white;
                      border: none;
                      border-radius: 10px;
                      font-size: 15px;
                      font-weight: 500;
                      cursor: pointer;
                      transition: all 0.2s;
                  }
          
                  .add-button:hover {
                      background: #0077ED;
                  }
          
                  .todo-list {
                      list-style: none;
                  }
          
                  .todo-item {
                      display: flex;
                      align-items: center;
                      padding: 16px;
                      border-radius: 10px;
                      margin-bottom: 8px;
                      transition: background-color 0.2s;
                  }
          
                  .todo-item:hover {
                      background-color: #f5f5f7;
                  }
          
                  .todo-checkbox {
                      width: 22px;
                      height: 22px;
                      margin-right: 15px;
                      cursor: pointer;
                  }
          
                  .todo-text {
                      flex: 1;
                      font-size: 17px;
                      color: #1d1d1f;
                  }
          
                  .completed {
                      color: #86868b;
                      text-decoration: line-through;
                  }
          
                  .delete-button {
                      padding: 8px 12px;
                      background: none;
                      color: #86868b;
                      border: none;
                      border-radius: 6px;
                      font-size: 15px;
                      cursor: pointer;
                      opacity: 0;
                      transition: all 0.2s;
                  }
          
                  .todo-item:hover .delete-button {
                      opacity: 1;
                  }
          
                  .delete-button:hover {
                      background: #f5f5f7;
                      color: #ff3b30;
                  }
          
                  .loading {
                      text-align: center;
                      padding: 20px;
                      color: #86868b;
                  }
          
                  .error {
                      color: #ff3b30;
                      text-align: center;
                      padding: 20px;
                  }
              </style>
          </head>
          <body>
              <div>
          
          
          
          <p>Aqui está a tradu??o para o inglês:</p>
          
          
          <hr>
          
          <h2>
            
            
            Setting Up the Routes
          </h2>
          
          <p>Update the src/App.php file to include the TodoList routes:<br>
          </p>
          
          <pre class="brush:php;toolbar:false">use App\Http\Controllers\TodoController;
          
          $app = new \Lithe\App;
          
          // Route for the main page
          $app->get('/', [TodoController::class, 'index']);
          
          // API routes
          $app->get('/todos/list', [TodoController::class, 'list']);
          $app->post('/todos', [TodoController::class, 'store']);
          $app->put('/todos/:id', [TodoController::class, 'update']);
          $app->delete('/todos/:id', [TodoController::class, 'delete']);
          
          $app->listen();
          

          Exécution de l'application

          Pour démarrer le serveur de développement, exécutez?:

          php line serve
          

          Accédez à http://localhost:8000 dans votre navigateur pour voir l'application en action.

          Fonctionnalités implémentées

          Notre TodoList présente les fonctionnalités suivantes?:

          1. Liste des taches par ordre chronologique inverse
          2. Ajout de nouvelles taches
          3. Marquer les taches comme terminées/en attente
          4. Supprimer des taches
          5. Interface réactive et conviviale
          6. Retour visuel pour toutes les actions
          7. Gestion des erreurs

          Conclusion

          Vous disposez désormais d'une application TodoList entièrement fonctionnelle construite avec Lithe. Cet exemple montre comment créer une application Web moderne avec PHP, notamment?:

          • Structure appropriée du code MVC
          • Implémentation de l'API RESTful
          • Interface utilisateur interactive
          • Intégration de base de données
          • Gestion des erreurs
          • Commentaires des utilisateurs

          à partir de là, vous pouvez étendre l'application en ajoutant de nouvelles fonctionnalités telles que?:

          • Authentification de l'utilisateur
          • Catégorisation des taches
          • Dates d'échéance
          • Filtres et recherche

          Pour continuer à en apprendre davantage sur Lithe, visitez le Linktree, où vous pouvez accéder au Discord, à la documentation et bien plus encore?!

          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

          Undress AI Tool

          Undress AI Tool

          Images de déshabillage gratuites

          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.

          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 grace à 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)

          Sujets chauds

          Tutoriel PHP
          1488
          72
          Porce de variable PHP expliquée Porce de variable PHP expliquée Jul 17, 2025 am 04:16 AM

          Les problèmes et les solutions courants pour la portée de la variable PHP incluent: 1. La variable globale ne peut pas être accessible dans la fonction, et elle doit être transmise en utilisant le mot-clé ou le paramètre global; 2. La variable statique est déclarée avec statique, et elle n'est initialisée qu'une seule fois et la valeur est maintenue entre plusieurs appels; 3. Des variables hyperglobales telles que $ _get et $ _post peuvent être utilisées directement dans n'importe quelle portée, mais vous devez faire attention au filtrage s?r; 4. Les fonctions anonymes doivent introduire des variables de portée parents via le mot clé Utiliser, et lorsque vous modifiez les variables externes, vous devez passer une référence. La ma?trise de ces règles peut aider à éviter les erreurs et à améliorer la stabilité du code.

          Comment gérer les téléchargements de fichiers en toute sécurité dans PHP? Comment gérer les téléchargements de fichiers en toute sécurité dans PHP? Jul 08, 2025 am 02:37 AM

          Pour gérer en toute sécurité les téléchargements de fichiers PHP, vous devez vérifier la source et taper, contr?ler le nom et le chemin du fichier, définir les restrictions du serveur et traiter les fichiers multimédias deux fois. 1. Vérifiez la source de téléchargement pour empêcher le CSRF via le jeton et détecter le type de mime réel via FINFO_FILE en utilisant le contr?le de liste blanche; 2. Renommez le fichier à une cha?ne aléatoire et déterminez l'extension pour la stocker dans un répertoire non Web en fonction du type de détection; 3. La configuration PHP limite la taille de téléchargement et le répertoire temporaire Nginx / Apache interdit l'accès au répertoire de téléchargement; 4. La bibliothèque GD résait les images pour effacer des données malveillantes potentielles.

          Commentant le code en php Commentant le code en php Jul 18, 2025 am 04:57 AM

          Il existe trois méthodes courantes pour le code de commentaire PHP: 1. Utiliser // ou # pour bloquer une ligne de code, et il est recommandé d'utiliser //; 2. Utiliser /.../ pour envelopper des blocs de code avec plusieurs lignes, qui ne peuvent pas être imbriquées mais peuvent être croisées; 3. Compétences combinées Commentaires tels que l'utilisation / if () {} / pour contr?ler les blocs logiques, ou pour améliorer l'efficacité avec les touches de raccourci de l'éditeur, vous devez prêter attention aux symboles de fermeture et éviter les nidification lorsque vous les utilisez.

          Comment les générateurs fonctionnent-ils en PHP? Comment les générateurs fonctionnent-ils en PHP? Jul 11, 2025 am 03:12 AM

          AgeneratorInphpisamemory-EfficientwaytoterateOrgedatasetsByyieldingValuesonEatatimeIntedofreturningThemallAtonce.1.GeneratorsUsEtheieldKeywordToproduceValuesondemand, ReducingMemoryUsage.2.TheyAreusefulForHandlingBigloops, ReadingLargeFiles, OR OR.

          Conseils pour écrire des commentaires PHP Conseils pour écrire des commentaires PHP Jul 18, 2025 am 04:51 AM

          La clé pour rédiger des commentaires PHP est de clarifier l'objectif et les spécifications. Les commentaires devraient expliquer "pourquoi" plut?t que "ce qui a été fait", en évitant la redondance ou trop de simplicité. 1. Utilisez un format unifié, tel que DocBlock (/ * /) pour les descriptions de classe et de méthode afin d'améliorer la lisibilité et la compatibilité des outils; 2. Soulignez les raisons de la logique, telles que pourquoi les sauts JS doivent être sortis manuellement; 3. Ajoutez une description d'une vue d'ensemble avant le code complexe, décrivez le processus dans les étapes et aidez à comprendre l'idée globale; 4. Utilisez TODO et FIXME Rationalement pour marquer des éléments et des problèmes de taches pour faciliter le suivi et la collaboration ultérieurs. De bonnes annotations peuvent réduire les co?ts de communication et améliorer l'efficacité de la maintenance du code.

          Comment accéder à un caractère dans une cha?ne par index en php Comment accéder à un caractère dans une cha?ne par index en php Jul 12, 2025 am 03:15 AM

          En PHP, vous pouvez utiliser des crochets ou des accolades bouclées pour obtenir des caractères d'index spécifiques à la cha?ne, mais les crochets sont recommandés; L'index commence à partir de 0 et l'accès à l'extérieur de la plage renvoie une valeur nulle et ne peut pas se voir attribuer une valeur; MB_substr est nécessaire pour gérer les caractères multi-octets. Par exemple: $ str = "Hello"; echo $ str [0]; sortie h; et les caractères chinois tels que MB_substr ($ str, 1,1) doivent obtenir le résultat correct; Dans les applications réelles, la longueur de la cha?ne doit être vérifiée avant le boucle, les cha?nes dynamiques doivent être vérifiées pour la validité et les projets multilingues recommandent d'utiliser des fonctions de sécurité multi-octets uniformément.

          Tutoriel d'installation rapide PHP Tutoriel d'installation rapide PHP Jul 18, 2025 am 04:52 AM

          Toinstallphpquickly, usexAmpPonWindowsorHomebrewonMacos.1.onwindows, downloadAndInstallxAmppp, selectComponents, startapache et placefilesInhtdocs.2.

          Apprendre PHP: un guide du débutant Apprendre PHP: un guide du débutant Jul 18, 2025 am 04:54 AM

          Toléarnphpeffective, startBySettingUpAlocalServerERironmentUsingToolsLILYXAMPPANDACODEDITERLIGHILLEVSCODE.1) INSTRUSITIONXAMPFORAPACHE, MYSQL, ANDPHP.2) USACODEDEDITORFORSYNTAXSUPPORT.3)

          See all articles