Rumah hujung hadapan web tutorial js Cara Saya Memperbaiki Isu Persediaan TypeScript Saya: Pengguna hartanah tidak wujud pada jenis Request.

Cara Saya Memperbaiki Isu Persediaan TypeScript Saya: Pengguna hartanah tidak wujud pada jenis Request.

Sep 18, 2024 pm 07:47 PM

How I Fixed My TypeScript Setup Issue: Property user does not exist on type Request.

Masalahnya
Saya telah mengusahakan projek Node.js dengan TypeScript dan Express.js. Pada satu ketika, saya perlu melampirkan objek pengguna pada objek Permintaan Ekspres, tetapi saya menghadapi ralat TypeScript ini:

'Pengguna' harta tidak wujud pada jenis 'Permintaan'.

Saya segera menyedari bahawa ini berlaku kerana objek Permintaan lalai Express tidak termasuk sifat pengguna dan TypeScript tidak berpuas hati dengannya.

Pembetulan Awal Saya
Untuk membetulkannya, saya melanjutkan antara muka Permintaan untuk menambah harta pengguna. Begini cara saya melakukannya:

  1. Saya mencipta fail baharu bernama express.d.ts dalam folder jenis dalam projek saya:
// src/types/express.d.ts
import { User } from '@prisma/client'; // Assuming User is a Prisma model

declare global {
    namespace Express {
        interface Request {
            user?: User; // Add user to the Request interface
        }
    }
}
Salin selepas log masuk
  1. Saya mengemas kini tsconfig.json saya untuk memastikan TypeScript mengambil jenis baharu ini:
{
  "compilerOptions": {
    //extra options here
    "typeRoots": ["./node_modules/@types", "./src/types"] // Add the types folder
  }
}

Salin selepas log masuk

Pada ketika ini, ralat hilang daripada editor kod saya, jadi saya fikir saya telah membetulkan masalah itu. Tetapi apabila saya cuba menjalankan projek itu, saya mengalami ralat lain dalam terminal:

ralat TS2339: 'Pengguna' harta tidak wujud pada jenis 'Permintaan'.

Tersekat Berhari-hari
Saya menghabiskan 3-4 hari untuk menyelesaikan masalah ini, mencuba semua yang saya temui dalam talian. Saya tersekat sepenuhnya dan tidak dapat memahami sebab ia tidak berfungsi.

Penyelesaian
Akhirnya, saya menemui isu akar dan membetulkannya dengan langkah berikut:

  1. Pasang TypeScript Secara Global: Saya menyedari bahawa saya tidak mempunyai pengkompil TypeScript (tsc) yang dipasang secara global, jadi saya menjalankan arahan ini:

npm pasang -g typescript

  1. Jalankan Pengkompil TypeScript dalam Mod Tontonan: Saya menggunakan bendera --watch untuk menyusun semula kod TypeScript saya secara automatik semasa saya bekerja:
    tsc --lihat

  2. Mulakan Semula Editor Kod Saya: Saya memulakan semula editor saya (Kod VS dalam kes saya) untuk memastikan semuanya dimuatkan dengan betul.

  3. Jalankan Projek: Selepas memulakan semula, saya menjalankan projek sekali lagi—dan ia berjaya!

Kesimpulan
Apa yang saya fikirkan sebagai isu kecil bertukar menjadi hari-hari kekecewaan, tetapi akhirnya saya berjaya! Jika anda menghadapi masalah yang sama dengan TypeScript tidak mengenali sifat baharu pada objek Permintaan Express, ingat untuk:

Panjangkan antara muka Permintaan dengan betul.
Pastikan pengkompil TypeScript (tsc) dipasang dan berjalan dengan betul.
Mudah-mudahan, ini membantu sesiapa sahaja yang terperangkap seperti saya!

Atas ialah kandungan terperinci Cara Saya Memperbaiki Isu Persediaan TypeScript Saya: Pengguna hartanah tidak wujud pada jenis Request.. 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

Tag artikel 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

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

Contoh warna json fail Contoh warna json fail Mar 03, 2025 am 12:35 AM

Contoh warna json fail

8 plugin susun atur halaman jquery yang menakjubkan 8 plugin susun atur halaman jquery yang menakjubkan Mar 06, 2025 am 12:48 AM

8 plugin susun atur halaman jquery yang menakjubkan

10 JQuery Syntax Highlighters 10 JQuery Syntax Highlighters Mar 02, 2025 am 12:32 AM

10 JQuery Syntax Highlighters

Bina Aplikasi Web Ajax anda sendiri Bina Aplikasi Web Ajax anda sendiri Mar 09, 2025 am 12:11 AM

Bina Aplikasi Web Ajax anda sendiri

Apa itu ' ini ' Dalam JavaScript? Apa itu ' ini ' Dalam JavaScript? Mar 04, 2025 am 01:15 AM

Apa itu ' ini ' Dalam JavaScript?

10 JavaScript & JQuery MVC Tutorial 10 JavaScript & JQuery MVC Tutorial Mar 02, 2025 am 01:16 AM

10 JavaScript & JQuery MVC Tutorial

See all articles