cari
Rumahpembangunan bahagian belakangGolangCara Membuat Sambungan Pelayan Langsung Mudah Menggunakan Golang

How to Create a Simple Live Server Extension Using Golang

Jika anda seorang pembangun web dan belum menggunakan sambungan Pelayan Langsung dalam VSCode, adakah anda seorang pembangun? Bergurau sahaja. Tetapi adakah anda berfikir tentang bagaimana ia berfungsi di bawah tudung? Dalam blog hari ini, mari cuba fahami cara ia berfungsi dengan pelaksanaan langsung menggunakan Golang. Kenapa Golang? Nah, saya sedang meneroka Golang hari ini, dan apakah yang lebih baik untuk dipelajari daripada membina projek? Jadi cukup konteks (bukan yang dalam golang ) mari kita mulakan.

Bagaimana pelayan langsung berfungsi?

Jadi pelayan langsung memuatkan semula penyemak imbas secara automatik apabila ia mengesan sebarang pengubahsuaian dalam fail html,css atau js. Ia bermula dengan menyampaikan fail statik ini melalui pelayan HTTP. Di bawah tudung ia menggunakan pemerhati fail seperti fsnotify(kami akan menggunakan ini untuk projek kami), fswatch (dalam sistem fail berasaskan UNIX) atau Chokidar(untuk Nodejs) untuk terus memantau direktori projek untuk perubahan fail (pada asasnya apabila anda simpan sebarang fail dengan sambungan .html,.css,.js ) .

Pada intinya ia Menggunakan sambungan WebSocket antara pelayan (nod js) anda dan penyemak imbas. Apabila pelayan mengesan perubahan fail, ia menghantar pemberitahuan muat semula melalui WebSocket ke penyemak imbas. Penyemak imbas, seterusnya, memuatkan semula halaman untuk mencerminkan perubahan baharu yang dibuat. Selain itu ia menggunakan suntikan CSS (mengemas kini hanya gaya tanpa muat semula penuh), HMR (penggantian modul panas) untuk modul javascript. Ini memastikan pembangun mendapat maklum balas masa nyata tanpa perlu memuatkan semula penyemak imbas secara manual selepas setiap perubahan dalam kod .

Gambaran keseluruhan projek

Jadi dengan projek ini, idea saya adalah sama. Matlamat saya adalah untuk melihat perubahan fail (seperti HTML, CSS dan JavaScript) dan mencetuskan muat semula penyemak imbas apabila sebarang pengubahsuaian dikesan. Untuk ini, saya menggunakan pelayan HTTP terbina dalam Go dan pakej fsnotify, yang memantau peristiwa sistem fail dengan cekap.

1. Melayan Fail Statik

Langkah pertama ialah menyediakan pelayan HTTP mudah dalam Go yang menyediakan fail statik daripada direktori. Fail statik, seperti HTML, CSS dan JavaScript, akan dimuatkan daripada folder ./static. Ini dikendalikan menggunakan http.FileServer:

http.Handle("/", http.FileServer(http.Dir("./static")))

2. Muat Semula Titik Akhir

Seterusnya, saya memerlukan titik akhir yang akan memberitahu pelanggan untuk memuat semula apabila perubahan fail dikesan. Laluan /reload bertindak sebagai pencetus, menghantar mesej "muat semula" ke penyemak imbas apabila pelayan mengesan pengubahsuaian:

http.HandleFunc("/reload", func(w http.ResponseWriter, r *http.Request) {
    



<p>Laluan ini mendengar acara pada saluran, yang kemudiannya akan diisi oleh pemberitahuan perubahan fail.</p>

<h2>
  
  
  3. Menonton Perubahan Fail
</h2>

<p>Saya memanfaatkan pakej fsnotify untuk menjejaki perubahan dalam jenis fail tertentu (HTML, CSS dan JS). Pemerhati mendengar sebarang pengubahsuaian dan menolak pemberitahuan ke saluran muat semula apabila ia mengesan perubahan:<br>
</p>

<pre class="brush:php;toolbar:false">func scanFileChanges() {
    watcher, err := fsnotify.NewWatcher()
    if err != nil {
        log.Fatal(err)
    }
    defer watcher.Close()

    for {
        select {
        case event := 



<h2>
  
  
  4. Menapis Fail yang Dijejaki
</h2>

<p>Bukan setiap perubahan fail harus mencetuskan muat semula, jadi saya menambah penapis yang hanya menjejak sambungan fail tertentu: .html, .css dan .js. Ini dilakukan menggunakan fungsi failpath.Ext untuk menyemak jenis fail:<br>
</p>

<pre class="brush:php;toolbar:false">func isTrackedFile(fileName string) bool {
    ext := strings.ToLower(filepath.Ext(fileName))
    return ext == ".html" || ext == ".css" || ext == ".js"
}

5. Menjalankan Pelayan

Akhir sekali, saya melancarkan pelayan HTTP untuk mendengar pada port 8000 dan memulakan proses menonton fail secara serentak:

log.Println("Starting the server at: 8000")
log.Fatal(http.ListenAndServe(":8000", nil))

Fikiran Akhir

Walaupun contoh ini memfokuskan pada memuatkan semula fail statik, terdapat banyak ruang untuk penambahbaikan—seperti menambahkan sokongan WebSocket untuk komunikasi yang lebih lancar, pengendalian fail yang lebih baik dan mengembangkan senarai fail yang dijejaki.

Dengan hanya beberapa baris kod Go, saya dapat memperbaik aliran kerja untuk pembangunan web statik dan saya berharap untuk memperhalusi alat ini dengan lebih jauh lagi.

Lihat kod: serve-it GitHub

Atas ialah kandungan terperinci Cara Membuat Sambungan Pelayan Langsung Mudah Menggunakan Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Golang vs Python: Konvensyen dan MultithreadingGolang vs Python: Konvensyen dan MultithreadingApr 17, 2025 am 12:20 AM

Golang lebih sesuai untuk tugas -tugas kesesuaian yang tinggi, sementara Python mempunyai lebih banyak kelebihan dalam fleksibiliti. 1.Golang dengan cekap mengendalikan kesesuaian melalui goroutine dan saluran. 2. Pilihannya harus berdasarkan keperluan khusus.

Golang dan C: Perdagangan dalam prestasiGolang dan C: Perdagangan dalam prestasiApr 17, 2025 am 12:18 AM

Perbezaan prestasi antara Golang dan C terutamanya ditunjukkan dalam pengurusan ingatan, pengoptimuman kompilasi dan kecekapan runtime. 1) Mekanisme pengumpulan sampah Golang adalah mudah tetapi boleh menjejaskan prestasi, 2) Pengurusan memori manual C dan pengoptimuman pengkompil lebih cekap dalam pengkomputeran rekursif.

Golang vs Python: Aplikasi dan Kes GunakanGolang vs Python: Aplikasi dan Kes GunakanApr 17, 2025 am 12:17 AM

PilihgolangforhighperformanceandConcurrency, IdealForBackEndServicesandnetworkprogramming; SelectPythonForrapidDevelopment, datascience, danMachinelearningDuetoitSversativilityAndextiveLibraries.

Golang vs Python: Perbezaan dan Persamaan UtamaGolang vs Python: Perbezaan dan Persamaan UtamaApr 17, 2025 am 12:15 AM

Golang dan Python masing -masing mempunyai kelebihan mereka sendiri: Golang sesuai untuk prestasi tinggi dan pengaturcaraan serentak, sementara Python sesuai untuk sains data dan pembangunan web. Golang terkenal dengan model keserasiannya dan prestasi yang cekap, sementara Python terkenal dengan sintaks ringkas dan ekosistem perpustakaan yang kaya.

Golang vs Python: Kemudahan Penggunaan dan Keluk PembelajaranGolang vs Python: Kemudahan Penggunaan dan Keluk PembelajaranApr 17, 2025 am 12:12 AM

Dalam apa aspek Golang dan Python lebih mudah digunakan dan mempunyai lengkung pembelajaran yang lebih lancar? Golang lebih sesuai untuk kesesuaian tinggi dan keperluan prestasi tinggi, dan lengkung pembelajaran agak lembut untuk pemaju dengan latar belakang bahasa C. Python lebih sesuai untuk sains data dan prototaip cepat, dan lengkung pembelajaran sangat lancar untuk pemula.

Perlumbaan Prestasi: Golang vs CPerlumbaan Prestasi: Golang vs CApr 16, 2025 am 12:07 AM

Golang dan C masing-masing mempunyai kelebihan sendiri dalam pertandingan prestasi: 1) Golang sesuai untuk kesesuaian tinggi dan perkembangan pesat, dan 2) C menyediakan prestasi yang lebih tinggi dan kawalan halus. Pemilihan harus berdasarkan keperluan projek dan tumpukan teknologi pasukan.

Golang vs C: Contoh kod dan analisis prestasiGolang vs C: Contoh kod dan analisis prestasiApr 15, 2025 am 12:03 AM

Golang sesuai untuk pembangunan pesat dan pengaturcaraan serentak, manakala C lebih sesuai untuk projek yang memerlukan prestasi yang melampau dan kawalan asas. 1) Model Concurrency Golang memudahkan pengaturcaraan konvensyen melalui goroutine dan saluran. 2) Pengaturcaraan templat C menyediakan kod generik dan pengoptimuman prestasi. 3) Koleksi sampah Golang adalah mudah tetapi boleh menjejaskan prestasi. Pengurusan memori C adalah rumit tetapi kawalannya baik -baik saja.

Impak Golang: Kelajuan, Kecekapan, dan KesederhanaanImpak Golang: Kelajuan, Kecekapan, dan KesederhanaanApr 14, 2025 am 12:11 AM

Goimpactsdevelopmentpositivielythroughspeed, efficiency, andsimplicity.1) Speed: goCompilesquicklyandrunsefficiently, idealforlargeproject.2) Kecekapan: ITSComprehensivestandardlibraryraryrarexternaldependencies, enhingdevelyficiency.

See all articles

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)
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna