Rumah hujung hadapan web tutorial js zod vs pengesah kelas & pengubah kelas

zod vs pengesah kelas & pengubah kelas

Dec 19, 2024 am 11:42 AM

zod vs class-validator & class-transformer

Perbandingan zod dengan pengesah kelas & pengubah kelas dalam NestJS

Saya keliru, atau sekurang-kurangnya ingin tahu antara zod atau pengesah kelas & pengubah kelas
sebagai pustaka pengesahan dalam NestJS.

Perkara Utama

Terus pergi ke sana.

1. Sebab untuk memilih pengesah kelas & pengubah kelas

  • Merupakan pakej duo yang biasa & digunakan secara meluas dalam NestJS
  • Kaedah penulisan sangat NestJS kerana ia pengesahan berasaskan penghias
  • integrasi bersih & lancar dengan penggunaannya dengan pengubah kelas & ValidationPipe

2. Sebab memilih Zod

  • Rangka kerja agnostik
  • Skrip taip sangat
  • Untuk mereka yang lebih suka pendekatan berfungsi & berasaskan skema
  • Prestasi & pengesahan ringan adalah kritikal

Butiran

pengesah kelas & pengubah kelas ialah 2 pakej yang paling biasa digunakan sebagai pengesahan dalam NestJS,
ya, selain daripada fakta bahawa kaedah penulisan adalah sama seperti NestJS menggunakan berasaskan penghias,
juga kerana ia bersih & lancar kerana ia boleh digunakan dengan ValidationPipe sebagai DTO.

Jadi data/muatan masuk yang diterima oleh pengawal telah disahkan & diubah/diubah mengikut definisinya.
Sementara itu, Zod masih perlu mengesahkan data/muatan yang diterima secara manual,
Ya, mungkin hanya 1 atau maksimum 3 baris,
tetapi sudah tentu lebih banyak fungsi pengesahan diperlukan, lebih banyak proses manual diperlukan.

Butiran prosedur

Berikut adalah prosedur terperinci (mungkin subjektif) untuk perbandingan.

pengesah kelas & pengubah kelas

1. Pemasangan

npm install class-validator class-transformer
Salin selepas log masuk

2. Dayakan Pengesahan Global

// main.ts
....
import { ValidationPipe } from '@nestjs/common';

async function bootstrap() {
....
  // Enable validation globally
  app.useGlobalPipes(new ValidationPipe({
    transform: true, // Automatically transform payloads to DTO instances
    whitelist: true, // Strip unknown properties
    forbidNonWhitelisted: true, // Throw error for unknown properties
  }));
....
}
....
Salin selepas log masuk

3. Tentukan DTO (Objek Pemindahan Data)

import { IsNotEmpty, IsString, IsInt, Min } from "class-validator";
import { Type, Transform } from "class-transformer";

export class CreateUserDto {
    @Transform(({ value }) => value.trim()) // Trim whitespaces
    @IsNotEmpty({ message: "Nama tidak boleh kosong" })
    @IsString({ message: "Nama harus berupa string" })
    @Min(3, { message: "Minimal panjang nama 3 karakter" })
    name: string;

    @Type(() => Number) // Transform input ke tipe Number
    @IsNotEmpty({ message: "Nama tidak boleh kosong" })
    @IsInt({ message: "Umur harus berupa bilangan bulat" })
    @Min(17, { message: "Minimal umur terdaftar 17 tahun" })
    age: number;
}
Salin selepas log masuk

Ia agak panjang, tetapi begitulah keadaannya berasaskan penghias.

4. Penggunaan pengesahan

import { Body, Controller, Post } from "@nestjs/common";
import { CreateUserDto } from "./create-user.dto";

@Controller("users")
export class UsersController {
    @Post()
    create(@Body() createUserDto: CreateUserDto) {
        // Pada titik ini data/payload createUserdDto
        // sudah tervalidasi & diubah sesuai definisinya
        // developer bisa langsung eksekusi service
        // atau logic yang lain
    }
}
Salin selepas log masuk

Zod

1. Pemasangan

npm install zod
Salin selepas log masuk

2. Buat Skim Pengesahan

// user.validaiton.ts
import { z, ZodType } from "zod";

export class UserValidation {
    static readonly CREATE: ZodType = z.object({
        name: z
            .string({ message: "Nama harus berupa string" })
            .nonempty({ message: "Nama tidak boleh kosong" })
            .min(3, "Minimal panjang nama 13 karakter"),
        age: z
            .number({ message: "Umur harus berupa angka" })
            .int({ message: "Umur harus berupa bilangan bulat" })
            .min(17, "Minimal umur terdaftar 17 tahub"),
    });
}

export type TCreateUserPayload = z.infer<typeof UserValidation.CREATE>;
Salin selepas log masuk

*Peribadi: Saya lebih suka membaca skema ini daripada skema di atas

3. Penggunaan pengesahan

import { Body, Controller, Post } from "@nestjs/common";
import { UserValidation, TCreateUserPayload } from "./user.validation.ts";

@Controller("users")
export class UsersController {
    @Post()
    create(@Body() createUserPayload: TCreateUserPayload) {
        const payload = UserValidation.CREATE.parse(createUserPayload);
        // Pada titik ini data/payload payload
        // sudah tervalidasi & diubah sesuai definisinya
        // developer bisa langsung eksekusi service
        // atau logic yang lain
    }
}
Salin selepas log masuk

Kesimpulan

Secara peribadi saya lebih suka cara Zod digunakan.
Namun, apa yang perlu digariskan ialah pilih mengikut keperluan & standard pasukan.

https://abdulghofurme.github.io/posts/zod-vs-class-validator-n-class-transformer/

Atas ialah kandungan terperinci zod vs pengesah kelas & pengubah kelas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Ganti aksara rentetan dalam javascript Ganti aksara rentetan dalam javascript Mar 11, 2025 am 12:07 AM

Ganti aksara rentetan dalam javascript

periksa jQuery jika tarikh sah periksa jQuery jika tarikh sah Mar 01, 2025 am 08:51 AM

periksa jQuery jika tarikh sah

jQuery mendapatkan padding/margin elemen jQuery mendapatkan padding/margin elemen Mar 01, 2025 am 08:53 AM

jQuery mendapatkan padding/margin elemen

10 Tab Accordion JQuery 10 Tab Accordion JQuery Mar 01, 2025 am 01:34 AM

10 Tab Accordion JQuery

10 patut diperiksa plugin jQuery 10 patut diperiksa plugin jQuery Mar 01, 2025 am 01:29 AM

10 patut diperiksa plugin jQuery

HTTP Debugging dengan Node dan HTTP-Console HTTP Debugging dengan Node dan HTTP-Console Mar 01, 2025 am 01:37 AM

HTTP Debugging dengan Node dan HTTP-Console

Tutorial Persediaan API Carian Google Custom Tutorial Persediaan API Carian Google Custom Mar 04, 2025 am 01:06 AM

Tutorial Persediaan API Carian Google Custom

jQuery tambah bar scroll ke div jQuery tambah bar scroll ke div Mar 01, 2025 am 01:30 AM

jQuery tambah bar scroll ke div

See all articles