สอนทำเว็บไซต์ด้วย Node.js, Express และ MongoDB ตอนที่ 1 - ติดตั้งโปรแกรม

Published on
NodeJS
2020/01/web-development-with-nodejs-mongodb-part1
Discord

สวัสดีครับ ผมเห็นว่าบทความเกี่ยวกับ Node.js ที่ผมเคยเขียนไว้ ช่วง 2015-2016 ก็ยังมีคนสนใจอยู่พอสมควร ผมจึงคิดว่า ปีนี้ 2020 ผ่านมาก็ 5ปีแล้ว เนื้อหามันค่อนข้างเก่า ฉะนั้นผมเลยตัดสินใจทำเป็น Series สอนเขียนเว็บด้วย Node.js และ MongoDB ขึ้นมาซะเลย ซึ่งก่อนหน้านี้ก็มีหลายบทความแล้ว แต่ว่ากระจัดกระจาย สำหรับคนที่มีพื้นฐาน หรือเคยเขียนมาบ้าง ก็สามารถทำความเข้าใจได้ไม่ยาก

แต่จะดีกว่า ถ้าผมรวบรวมทำมันเป็นบทสอน แบบตั้งแต่ ต้น จนเขียนได้เลย เรียกว่าเป็นกึ่งๆ สอน และ Workshop ไปด้วยครับ จบบท ก็สามารถทำเว็บไซต์ และ Deploy เว็บ ด้วย Node.js ได้เลยครับ

ซึ่งความคาดหวังและจุดประสงค์ของผมมี 2 ข้อครับ คือ

  1. อยากให้ผู้เรียนสามารถทำเว็บด้วย Node.js ได้ และสามารถนำความรู้ไปต่อยอดได้ในอนาคตครับ อยากเห็น dev เก่งๆเพิ่มเยอะๆครับ
  2. ผมอยากทบทวนตัวเองไปในตัวด้วยครับ เป็นการทบทวน ฝึกการเรียบเรียง การจัดหมวดหมู่ และถ่ายทอดครับ เพราะผมเชื่อเสมอว่าถ้าเราไม่สามารถถ่ายทอดความรู้เราออกไปได้ แสดงว่าเรายังไม่เก่ง ฉะนั้นผมก็เลยแค่อยากฝึก อยากลองทำมันครับ

หวังว่าจะชื่นชอบกันะครับ ซึ่งถ้าติดปัญหาตรงไหน หรือส่วนไหนผมผิดพลาดก็สอบถาม หรือเสนอแนะเข้ามาได้เลยครับ

เนื้อหาบทเรียน

Prerequisite

สิ่งที่ต้องมีสำหรับคอร์สเรียน Node.js และ MongoDB คือ

  • เข้าใจ Web พื้นฐาน เช่นรู้ว่า HTML&CSS คืออะไร และ Client & Server แตกต่างกันอย่างไร (เพราะต้องเข้าใจ request และ response) ถ้าไม่เข้าใจ ลองค้นหาเพิ่มเติมดูครับ
  • สามารถใช้ VS Code ได้ (Visual Studio Code)
  • สามารถใช้ Command Line เบื้องต้นได้ เช่น Terminal (บน Mac OS) หรือ ใช้ Terminal built-in ของ VS Code

Node.js คืออะไร ?

Node JS

Node.js คือ JavaScript runtime สำหรับฝั่ง Server และเป็น Open Source ซึ่งเขียนด้วยภาษา JavaScript สรุปรวมๆ NodeJS ก็คือ Platform ตัวหนึ่งที่เขียนด้วย JavaScript สำหรับเป็น Web Server นั่นเอง ซึ่งจะแตกต่างจากการเขียน JavaScript ที่ฝั่ง Client เล็กน้อย เช่น ไม่มี document.getElementById() หรือ window.alert() แต่จะมีสิ่งที่เรียกว่า Module เข้ามาแทน ซึ่งเป็นคล้ายๆ built-in library นั่นเอง

  • Node.js นั้นเป็น Non-blocking I/O นั่นคือ มันจะทำงานโดยที่ไม่ต้องรอกัน ปกติถ้าเป็นแบบ Blocking คือ เมื่อคำสั่งแรกทำงาน ก็ต้องรอจนจบ task ถึงจะเริ่มทำคำสั่งที่สองได้ แต่ถ้า Non-blocking แบบ Node.js คือสามารถทำงานที่สองได้เลย โดยที่ไม่ต้องรอให้งานแรกเสร็จก่อน

เริ่มต้นติดตั้ง Node.js

การติดตั้ง Node.js ทำได้ง่ายมาก เพียงแค่เข้าเว็บ Node.js Download จากนั้นเลือก OS ที่เราใช้งาน และทำการ ติดตั้งตาม Guide ได้เลย โดยแนะนำให้เลือกเวอร์ชั่นที่เป็น LTS ครับ คือ Long Term Support นั่นเอง

Download Node.js

ปัจจุบัน ณ ที่เขีนยบทความ Node.js LTS เวอร์ชั่น 12.14.0

สำหรับคนใช้ Mac OS สามารถติดตั้งผ่าน Homebrew ได้เช่นกัน

brew install node

โดยเมื่อเราทำการติดตั้ง Node.js เสร็จเรียบร้อยแล้วนั้น เราสามารถเช็ดดูว่า Node.js เราติดตั้งได้ถูกต้องจริงหรือเปล่า โดยการเปิด Terminal ขึ้นมา จากนั้นพิมพ์

node -v

ต้องได้ผลลัพธ์ประมาณนี้ (เวอร์ชั่นอาจจะต่างกันเล็กน้อย)

v12.14.0

หรือตรวจสอบ npm (พูดถึงในหัวข้อถัดไป) ด้วยคำสั่ง

npm -v

ก้จะได้ผลลัพธ์เช่น

6.11.3

โดยปกติแล้ว Node.js จะมาพร้อมกับ REPL (Read-Eval-Print-Loop) เป็นเสมือนกับ built-in IDE อะครับ เราสามารถเข้าโหมดนี้แล้วลองใช้คำสั่ง Node.js ได้ครับ เช่น

ทดลองเปิด Terminal ขึ้นมา หรือจะใช้ VS Code แล้วเปิด -> Terminal ครับ (View -> Terminal)

node

เราจะได้หน้าตาแบบนี้

Welcome to Node.js v12.14.0.
Type ".help" for more information.
>

หลังจากเครื่องหมาย > เราสามารถพิมพ์คำสั่งของ JavaScript ลงไปได้เลย (Node.js ก็คือ JavaScript ครับ ที่สามารถรันบน Server ได้)

console.log('Ahoy!');

จะได้ผลลัพธ์

Ahoy!
undefined

สามารถกด Tab เพื่อดูคำสั่ง หรือ module ต่างๆ ที่เราสามารถใช้ได้ (ทดลองกดดูได้ครับ) ผลลัพธ์ประมาณนี้

Array                 ArrayBuffer           Atomics               BigInt
BigInt64Array         BigUint64Array        Boolean               Buffer
DataView              Date                  Error                 EvalError
Float32Array          Float64Array          Function              GLOBAL
Infinity              Int16Array            Int32Array            Int8Array
Intl                  JSON                  Map                   Math
NaN                   Number                Object                Promise
Proxy                 RangeError            ReferenceError        Reflect
RegExp                Set                   SharedArrayBuffer     String
Symbol                SyntaxError           TextDecoder           TextEncoder
TypeError             URIError              URL                   URLSearchParams
Uint16Array           Uint32Array           Uint8Array            Uint8ClampedArray
WeakMap               WeakSet               WebAssembly           _
_error                assert                async_hooks           buffer
...
...

พวกนี้คือ module และ function ที่เราสามารถใช้ได้ครับ มีทั้งของ Node.js และของ JavaScript ครับ

สร้างโปรเจ็คแรกด้วย Node.js

ต่อมาครับ มาลองสร้างโปรเจ็คแรกด้วย Node.js กันครับ สร้างโฟลเดอร์ขึ้นมาปกติ หรือสร้างจาก VS Code ก็ได้ครับ

mkdir hello-nodejs

จากนั้นสร้างไฟล์ขึ้นมา 1 ไฟล์ ชื่อ app.js ใส่ข้อมูลดังนี้

const name = 'Devahoy'

const hello = name => `Hello ${name}`

const sum = (a, b) => a + b

const result = sum(2, 3)

console.log('result', result)

ผมมีทั้งตัวแปร และฟังค์ชั่นในไฟล์นี้ เราสามารถสั่งรันโปรแกรมด้วย Node โดยใช้คำสั่ง

node <FILE_NAME>

เช่น

node app.js

จะได้ผลลัพธ์เป็น

5

ต่อมา Node.js เราสามารถ ที่จะแชร์ข้อมูลระหว่าง 2 ไฟล์ได้ครับ เช่น ใช้ function อีกไฟล์ได้ (เหมือนหลายๆภาษา ที่สามารถ import library เข้ามาใช้)

ซึ่งใน Node.js เราเรียกกันว่า export / require module ครับ เราลองมาดูการใช้งานง่ายๆครับ เช่น จากไฟล์ app.js ด้านบน

ทำการเพิ่มโค๊ด บรรทัดนี้ต่อท้าย

module.exports = sum

คือการ export ฟังค์ชั่น sum เพื่อแชร์ให้ไฟล์อื่นไปใช้งานได้ ลองสร้างไฟล์ใหม่ สมมติชื่อ main.js

const sum = require('./app.js')

const result = sum(10, 20)

console.log('main.js > ', result)

การ import ไฟล์หรือฟังค์ชั่น เราจะใช้คำสั่ง require() ครับ เพื่อ import ไฟล์ที่เราต้องการ (สามารถย่อเหลือแค่ ./app ได้โดยไม่ต้องมีนามสกุล .js)

และสั่งรันด้วยคำสั่ง node app.js เราก็จะได้ผลลัพธ์เป็น 30 ครับ

นอกจากนี้ module.exports เราสามารถ export หลายๆ function ได้เช่น

module.exports.name = name
module.exports.hello = hello
module.exports.sum = sum

หรือ

module.exports = {
  name,
  hello,
  sum
}

ซึ่งถ้าใครไม่ค่อยเข้าใจ syntax ด้านบน เดี๋ยวรออ่านเพิ่มเติมเรื่อง Modern JavaScript ครับ

Recap

สรุปสำหรับ ตอนที่ 1 - ก็ยังเป็นพื้นฐานอยู่ครับ สิ่งที่ได้คือ

  • ติดตั้ง Node.js และ npm
  • Node.js ก็คือ JavaScript แค่อยู่บนฝั่ง Server
  • ใช้คำสั่ง node <FILENAME> เพื่อรันคำสั่ง node.js
  • ใช้คำสั่ง module.exports เพื่อ export ไฟล์
  • ใช้คำสั่ง require('./file') เพื่อ import ไฟล์

สำหรับบทความนี้ก็ขอจบเพียงเท่านี้ครับ หวังว่าจะชื่นชอบกัน และก็ฝากติดตามตอนต่อๆไปด้วยครับ เมื่อตอนใหม่มา ผมจะมาอัพเดท Table of Contents ของบทความนี้ และพยายามทำ link ไว้ทุกๆบทความให้อ่านง่ายครับ

สุดท้ายใครมีปัญหา ติดปัญหาตรงไหน สามารถสอบถามเพิ่มเติมได้ตลอดครับ

ต่อ ตอนที่ 2 ได้เลยครับ ทบทวนพื้นฐาน JavaScript และ Modern JavaScript ES6, ES7+

❤️ Happy Coding

Buy Me A Coffee
Authors
Discord