สวัสดี Deno - ลองเขียนเว็บด้วย Deno กันดีกว่า
Deno คืออะไร? Deno เป็น JavaScript Runtime ที่คล้ายๆ Node.js (คนสร้าง Node.js มาสร้าง Deno ด้วยแนวคิดที่ดีกว่าเดิม) ไม่ใช่แค่ JavaScript Runtime แต่ตัวเว็บบอกไว้ว่า Deno คือ JavaScript, TypeScript, และ WebAssembly Runtime เลยแหละ
ข้อดีของ Deno คือ
- single executable (deno)
- รองรับ TypeScript โดยไม่ต้องตั้งค่าอะไรเพิ่มเลย
- มีพวก format, linter มาให้เลย
- เรื่องความปลอดภัย (ไม่สามารถเข้าถึงไฟล์, network หรือค่าต่างๆได้ ถ้าเราไม่ได้เปิด)
- รองรับ npm ของ Node.js ด้วยนะ
สำหรับบทความนี้ เราไปลองดู Deno เบื้องต้นกันดีกว่าครับ ซึ่งหากใครเคยเขียน Node.js มาก่อน รับรองว่าเรียนรู้ได้ง่ายมาก เพราะเกือบจะเหมือน Node.js เลยก็ว่าได้
ณ วันที่เขียนบทความ คือ Deno v.1.31.1 ครับ
การติดตั้ง Deno
หากใครใช้ Linux หรือ Mac OS ก็สามารถใช้ Command Line นี้ได้เลย
ถ้าใช้ Homebrew ก็ง่ายๆแบบนี้
ส่วน Windows ใช้ Power Shell หรือ Scoop ก็ติดตั้งแบบนี้
Scoop
เมื่อติดตั้งเรียบร้อยแล้ว ทดสอบดูว่าได้ version info หรือไม่
จะได้ผลลัพธ์แบบนี้ (ขึ้นอยู่กับเวอร์ชั่นของแต่ละคน)
VS Code Extensions
ส่วนของ Extension ใน VS Code จะใช้ตัวนี้ (เนื่องจากคิดว่าเกิน 80% น่าจะใช้ VS Code ในการเขียน)
Hello World Deno
สร้างไฟล์ hello.ts
ขึ้นมา (จริงๆ มันก็คือ TypeScript ธรรมดาเลย) เราสามารถรัน TypeScript โดยที่ไม่ต้อง compile เป็น JavaScript
จากนั้น เราก็สั่งรันโปรแกรมผ่าน Terminal ได้แบบนี้
นอกจากนี้ เรายังสามารถให้ deno ทำการรัน (execute) ไฟล์จาก url ได้ด้วย แบบนี้
Fetch Data
อีกตัวอย่างนึงง่ายๆ คือการ ดึงข้อมูล Github API ด้วยการใช้ fetch ข้อมูล Github User (ของผมเอง) ตัว Deno รองรับการใช้ await on top ด้วย โดยไม่จำเป็นต้องอยู่ภายใน async function แบบนี้
จะเห็นว่า deno จะไม่ให้เรารัน เพื่อส่ง request ออก ถ้าไม่ได้อนุญาต ฉะนั้นเราก็ต้องใส่ --allow-net
เข้าไปด้วย
เราสามารถกด y
เพื่ออนุญาต สำหรับคำสั่งนี้
หรือรันคำสั่งใหม่ ด้วยการส่ง option ไปด้วย แบบนี้
ก็จะได้ผลลัพธ์เป็น Github Profile ของผม นั่นเอง
หวังว่าจะได้ไอเดีย ในการเรียนรู้ Deno นะครับ ลองไปฝึก และเรียนรู้เพิ่มเติมดูนะครับ
Happy Coding ❤️
อ่านเพิ่มเติม
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust