Dengan populariti Node.js, ia digunakan untuk pembangunan JavaScript dari bahagian hadapan ke bahagian belakang. Walau bagaimanapun, apabila kami memproses aksara Cina dalam Node.js, kadangkala kami menghadapi aksara yang bercelaru. Masalah ini menjadi lebih ketara apabila kami cuba menggunakan kod Node.js dalam penyemak imbas. Artikel ini akan meneroka sebab dan penyelesaian untuk aksara bercelaru dalam penyemak imbas Node.js.
1. Masalah pengekodan
Sebab pertama mungkin masalah pengekodan. Dalam Node.js, JavaScript menggunakan pengekodan Unicode (UTF-16 atau UCS-2) secara lalai. Oleh itu, jika kami menggunakan fail teks yang dikodkan bukan Unikod, aksara yang bercelaru mungkin muncul. Untuk membetulkannya, kami perlu memastikan bahawa fail teks kami menggunakan pengekodan yang sama seperti Node.js. Secara amnya, UTF-8 ialah pengekodan yang paling biasa digunakan.
2. Masalah membaca dan menulis fail
Sebab kedua mungkin masalah membaca dan menulis fail. Dalam Node.js, kita boleh menggunakan modul Sistem Fail untuk membaca dan menulis fail. Walau bagaimanapun, apabila menggunakan modul ini, kita perlu memberi perhatian kepada bagaimana fail dikodkan. Jika fail yang kami baca menggunakan pengekodan bukan Unikod, kami perlu menentukan pengekodan fail semasa membaca.
Sebagai contoh, kita boleh menggunakan kod berikut untuk membaca fail yang dikodkan GB2312:
const fs = require('fs'); fs.readFile('myfile.txt', 'binary', (err, data) => { if (err) throw err; console.log(data); })
Parameter 'binari' menunjukkan bahawa kaedah pengekodan membaca fail ialah strim binari. Walau bagaimanapun, kita perlu memberi perhatian kepada masalah, kerana Node.js tidak menyokong kaedah pengekodan 'binary' di bahagian pelayar, jadi apabila kod dijalankan dalam penyemak imbas, kaedah pengekodan 'binary' perlu ditukar kepada kaedah pengekodan lain, seperti 'utf8'.
3. Pengepala respons pelayan
Sebab ketiga ialah pengepala respons pelayan. Dalam Node.js, kita boleh menggunakan modul HTTP untuk mencipta pelayan. Apabila kami membuat pelayan menggunakan modul HTTP, kami perlu menetapkan pengepala respons. Jika kami tidak menetapkan kaedah pengekodan pengepala respons dengan betul, ia boleh menyebabkan penyemak imbas memaparkan aksara bercelaru.
Sebagai contoh, dalam kod berikut, kami mencipta pelayan HTTP dan menetapkan atribut Content-Type bagi pengepala respons:
const http = require('http'); http.createServer((req, res) => { res.writeHead(200, {'Content-Type': 'text/plain; charset=utf-8'}); res.end('你好,世界!'); }).listen(8080);
Dalam pengepala respons, kami menetapkan atribut Content-Type kepada "text/plain; charset=utf-8" bermakna teks yang kami pulangkan ialah teks biasa dan menggunakan pengekodan UTF-8.
Apabila kami mengakses pelayan ini dalam penyemak imbas, penyemak imbas akan menyahkod dan memaparkannya mengikut atribut Jenis Kandungan pengepala respons. Jika kami tidak menetapkan pengepala respons dengan betul, penyemak imbas mungkin tidak dapat menyahkod teks dengan betul, mengakibatkan teks bercelaru.
4. Pengekodan aksara penyemak imbas
Akhir sekali, pengekodan aksara penyemak imbas juga boleh menyebabkan penyemak imbas memaparkan aksara yang bercelaru. Pelayar yang berbeza mungkin menggunakan pengekodan aksara yang berbeza apabila memaparkan teks. Oleh itu, kami perlu memastikan bahawa pengekodan aksara penyemak imbas kami adalah sama dengan pengekodan teks kami.
Sebagai contoh, dalam penyemak imbas Chrome, kita boleh melihat pengekodan aksara yang digunakan oleh halaman melalui "Lihat kod sumber halaman".
Di atas ialah empat sebab yang mungkin menyebabkan Node.js kelihatan bercelaru dalam penyemak imbas. Penyelesaian kepada masalah ini juga sangat mudah, cuma pastikan fail teks kami menggunakan pengekodan yang betul, nyatakan pengekodan dengan betul semasa membaca fail, tetapkan pengepala respons dengan betul semasa membuat pelayan HTTP, dan semak pelayar kami Adakah watak itu pengekodan betul?
Atas ialah kandungan terperinci Nodejs bercelaru dalam penyemak imbas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!