miniframe-router — penghala minimalis untuk aplikasi Express.JS, diilhamkan oleh Ruby on Rails. Begini cara saya membuatnya.
Contoh cara penghalaan mungkin kelihatan dalam aplikasi mudah.
// Root routes root("index#home"); // Basic CRUD routes get("/users", "users#index"); get("/users/:id", "users#show"); post("/users", "users#create"); post("/users/:id", "users#update"); post("/users/:id/destroy", "users#destroy"); // Posts routes with scope scope("blog", () => { get("/posts", "posts#index"); get("/posts/:id", "posts#show"); post("/posts", "posts#create"); post("/posts/:id", "posts#update"); post("/posts/:id/destroy", "posts#destroy"); });
Saya tidak menulis aplikasi NodeJS selama kira-kira 10 tahun. Ingin tahu tentang Aplikasi Mini Telegram, saya memutuskan untuk membina beberapa projek mudah untuk meneroka bidang baharu ini.
Untuk ini, saya memerlukan penghalaan untuk bahagian belakang aplikasi saya. Penyelesaian sedia ada tidak begitu menarik perhatian saya, jadi saya memutuskan untuk mencipta penghala saya sendiri — mudah, berkesan dan diilhamkan oleh Ruby on Rails. Ia juga merupakan peluang yang baik untuk menyegarkan pengetahuan saya tentang mencipta pakej NPM, sesuatu yang tidak pernah saya lakukan selama 9 tahun.
Ini memudahkan struktur aplikasi dan mengelakkan kekacauan fail aplikasi utama.
import { root, get, post, routeScope as scope, getRouter, } from "miniframe-router"; // Root routes root("index#home"); // Basic CRUD routes get("/users", "users#index"); get("/users/:id", "users#show"); post("/users", "users#create"); post("/users/:id", "users#update"); post("/users/:id/destroy", "users#destroy"); // Posts routes with scope scope("blog", () => { get("/posts", "posts#index"); get("/posts/:id", "posts#show"); post("/posts", "posts#create"); post("/posts/:id", "posts#update"); post("/posts/:id/destroy", "posts#destroy"); }); export default getRouter;
Titik masuk yang mudah dan berkesan untuk aplikasi: src/index.js atau src/main.js.
import express from "express"; import getRouter from "./routes"; // <<< DEFINE ROUTES const app = express(); app.use(express.json()); app.use(getRouter()); // <<< USER ROUTES app.listen(3000, () => { console.log("Demo app is running on http://localhost:3000"); });
Pengawal terletak dalam direktori src/pengawal.
MyApp └── src ├── controllers │ ├── blog │ │ └── postsController.ts │ ├── indexController.ts │ └── usersController.ts ├── index.ts └── routes └── index.ts
Contoh: src/controllers/usersController.ts (atau .js).
// Root routes root("index#home"); // Basic CRUD routes get("/users", "users#index"); get("/users/:id", "users#show"); post("/users", "users#create"); post("/users/:id", "users#update"); post("/users/:id/destroy", "users#destroy"); // Posts routes with scope scope("blog", () => { get("/posts", "posts#index"); get("/posts/:id", "posts#show"); post("/posts", "posts#create"); post("/posts/:id", "posts#update"); post("/posts/:id/destroy", "posts#destroy"); });
Kod dan dokumentasi projek: GitHub - miniframe-router
Pakej NPM: miniframe-router
Suka, kongsi dan langgan! Maklum balas yang membina sentiasa dialu-alukan.
Halaman pengarang: GitHub - the-teacher
Atas ialah kandungan terperinci miniframe-router: Penghala untuk Aplikasi Express.JS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!