Forum

แบ่งปัน:
การแจ้งเตือน
ลบทั้งหมด

Svelte คืออะไร? มาทำความรู้จัก Framework ตัวนี้กันเถอะ

1 โพสต์
1 ผู้ใช้
0 Reactions
754 เข้าชม
nopparat.jap
(@nopparat-jap)
Trusted Member
เข้าร่วม: 5 ปี ที่ผ่านมา
กระทู้: 18
หัวข้อเริ่มต้น  

 

Svelte คืออะไร?

Svelte เป็น framework ที่ใช้ในการออกแบบ User interface เหมือนกับ framework อื่นที่มีกฎเกณฑ์, รูปแบบและข้อบังคับการเขียน code ให้นักพัฒนา front-end เช่น React, Angular, Vue ปัจจุบัน Svelte พัฒนามาจนถึงเวอร์ชั่น 3.38.2 แล้วซึ่งในเวอร์ชั่นแรก Svelte ยังเป็นแค่การทดสอบสมมุติฐาน ที่มีจุดประสงค์ที่จะสร้าง Compiler แปลง code ขึ้นมา เวอร์ชั่นต่อมาเป็นการอัพเกรดเล็กน้อยเพื่อให้เป็นระเบียบมากขึ้น และเวอร์ชั่นล่าสุดอย่างเวอร์ชั่น 3 ที่เป็นการยกเครื่องใหม่เพื่อสร้างประสบการณ์พัฒนาที่เอกลักษณ์ และเหตุใดกันเล่าทำให้ Svelte แตกต่างจาก framework อื่นและมีแนวโน้มจะเป็น UI framework ที่เป็นที่นิยมในอนาคต

Svelte website 300w, 768w, 1536w, 2048w" data-lazy-sizes="(max-width: 743px) 100vw, 743px" data-lazy-src="https://www.designil.com/wp-content/uploads/2021/06/1_TXpXgiGQnc1hhkOCoWPgeg-1024x512.png" data-ll-status="loaded" />
Svelte website

3 สิ่งที่ทำให้ Svelte แตกต่าง

1. Flexible and write less code

Svelte เป็น Compiler นั่นหมายความว่า code ในไฟล์ Svelte จะถูกแปลงจาก Hybrid language ที่ผสมระหว่าง HTML, CSS, JavaScript ให้เป็น lower-level optimize file แทน ซึ่งมันจะคล้ายกับวิธีคอมไฟล์ C# เป็น bytecode แต่ Svelte จะผสมทั้ง 3 ภาษาเข้าด้วยกัน นั่นทำให้การเขียน code มีความยืดหยุ่นมากขึ้น รวมทั้งยังเป็นประโยชน์ต่อเว็บเบราว์เซอร์อีกด้วย นอกจากความยืดหยุ่นในการเขียน code แล้ว Svelte ยังมีเป้าหมายในการลดจำนวน code ที่เขียนลงด้วย ยกตัวอย่างเช่น code บวกเลขข้างล่างของ 3 framework ทั้ง React, Vue และ Svelte

How Svelte works 300w, 768w, 1536w, 1600w" data-lazy-sizes="(max-width: 694px) 100vw, 694px" data-lazy-src="https://www.designil.com/wp-content/uploads/2021/06/EHKg1oRXUAICrqM-1024x512.jpg" data-ll-status="loaded" />
How Svelte works
credit : https://pbs.twimg.com/media/EHKg1oRXUAICrqM?format=jpg&name=large

React

import React, { useState } from 'react';

export default () => {
  const [a, setA] = useState(1);
  const [b, setB] = useState(2);

  function handleChangeA(event) {
    setA(+event.target.value);
  }

  function handleChangeB(event) {
    setB(+event.target.value);
  }

  return (

{a} + {b} = {a + b}


  );
};

Vue

{{a}} + {{b}} = {{a + b}}





Svelte




{a} + {b} = {a + b}

จะเห็นได้ว่า React code มีจำนวนที่เยอะกว่า Svelte ถีง 3 เท่า ซึ่งเป็นเรื่องปกติที่ความแตกต่างจะชัดเจนขนาดนีี้ จากที่ผมได้ทำการศึกษามา องค์ประกอบของ React มักจะมีจำนวนมากกว่า Svelte ประมาณ 40 %

2. No virtual DOM

DOM(Document Object Model) คือ interface ที่กำหนดโครงสร้างของเว็บไซต์ มันจะนำ HTML มาเปลี่ยนเป็นโครงสร้างที่สามารถจัดการและเข้าถึงได้ ในส่วนของ Virtual DOM จะเป็นการเพิ่ม concept ในการจำลอง DOM ขึ้นมาในหน่วยความจำและนำมาใช้ในการอัพเดต DOM เฉพาะจุดที่เปลี่ยนแปลงเมื่อ state ในแอพพลิเคชั่นมีการเปลี่ยนแปลง เมื่อสร้าง Virtual DOM แล้วจะรวมตัวกับ DOM และแสดงผลออกมาเป็น User Interface ที่เราเห็นกัน

ในอดีต 6 – 7 ปีก่อน Vitrual DOM ถือว่าเป็นเทคโนโลยีใหม่ที่มีความเร็วสูงมาก แต่ปัจจุบันเว็บไซต์มีการพัฒนาที่มากขึ้นทำให้เกิดผลกระทบของ DOM ที่ซ้ำกันในหน่วยความจำซึ่งจะส่งผลให้ประสิทธิภาพการทำงานแย่ลงได้แต่ Svelte มีแนวทางที่แตกต่างออกไป นั่นคือการไม่ใช้ Virtual DOM นั่นทำให้แอพพลิเคชั่นมีประสิทธิภาพที่ดีขึ้นอีกด้วย

Svelte Compiler vs Virtual DOM
Compiler VS Virtual DOM
credit https://miro.medium.com/max/2958/1*_7upPeJparkaxnpBhOkZig.png

3. CSS scope

ความแตกต่างระหว่าง CSS ใน Svelte และ CSS ใน framework อื่นๆคือ Svelte จะนำ CSS จากแต่ละ component มาแบ่งให้เป็น CSS แต่ละไฟล์ในช่วงระหว่าง build ยกตัวอย่างเช่นใน React จะเป็นการจัดเรียงแต่ละ component ทั้ง markup และ JavaScript ส่วน Svelte จะเป็นการรวบรวมแทนทั้ง markup และ JavaScript ให้อยู่ใน”.svelte” ไฟล์เดียว ซึ่งจะคล้ายกับ Vue

Svelte จะสร้างชื่อ class ที่ไม่ซ้ำกันขณะที่ compile เพื่อสร้างความแน่ใจว่า style แต่ละ element จะไม่เกิดความขัดแย้งซึ่งกันและกัน นั่นแสดงว่าเพื่อนๆสามารถที่จะใช้ selector โดยไม่จำเป็นโยงกับ class name อีก

Anatomy of Svelte
Anatomy of Svelte
credit : https://pbs.twimg.com/media/EHKg3L0X0AASviE?format=jpg&name=large

เปรียบเทียบ Svelte กับ framework อื่นๆ

เราจะทำการเปรียบเทียบ Svelte กับ React, Vue, Angular โดยใช้ เกณฑ์ 2 ข้อในการพิจรณา ได้แก่

  • 1.Popularity
  • 2.Performance

1. Popularity

Svelte dowload compare other frameworks.
ยอดดาวน์โหลด framework ในช่วง 5 ปี

เมื่อเอา Svelte มาเปรียบเทียบความนิยมกับ framework ดังๆ ณ ปัจจุบัน(React, Vue, Angular) จะเห็น Svelte ยังไม่เป็นที่นิยมอยู่มาก อาจเพราะ Svelte ยังเป็นแค่น้องใหม่ในวงการ framework เหมือนกับ React, Vue, Angular ในช่วงแรกที่ยังไม่ค่อยมีคนรู้จักกัน

2. Performance

ในการเปรียบเทียบ Performance บน website ของ framework ผมจะใช้ตาราง 3 ตัวในการเปรียบเทียบได้แก่ Speed test, Startup test, Memory allocation test ซึ่งเราตารางมาจาก Interactive Results เพื่อเปรียบเทียบ

Speed test

Svelte speed test framework
Speed test

จากสีโดยรวมในตารางจะเห็นได้ว่า Svelte และ Vue มี performance ที่ดีที่สุดในหมวดนี้ โดยทางด้านซ้ายจะเป็น action ส่วนขวาจะเป็นผลลัพธ์เวลาเฉลี่ย ในส่วนตารางบรรทัดสุดท้าย Slowdown geometric เป็นตัวชี้วัดของ performance และความเร็วโดยรวมของแต่ละ framework ซึ่งเราจะสรุปได้ว่า

  1. Vue – 1.17 slowdown geometric mean
  2. Svelte – 1.19 slowdown geometric mean
  3. React & Angular – 1.27 slowdown geometric mean

Startup test

Svelte startup test framework
Startup test

จากตาราง ชัดเจเลยว่าในหมวดหมู่นี้ Svelte ชนะอย่างชัดเจน ซึ่งสรุปได้ว่า

  1. Svelte
  2. Vue
  3. React
  4. Angular

Memmory allocation test

Svelte memmory test
Memmory allocation test

ผลลัพธ์เหมือนกับ Startup test Svelte ยังคง Top ฟอร์มอีกตามเคย Vue และ React ค่อนข้างใกล้เคียงกัน ส่วน Angular ในหมวดนี้ Performance ก็ยังคงต่ำสุดเช่นเคย

  1. Svelte
  2. Vue
  3. React
  4. Angular

Let’s start first project !!!

หลังจากศึกษาเรียนรู้มาพอสมควรเพื่อนๆ คงจะเริ่มสนใจ Svelte กันเข้าแล้ว งั้นเรามาเริ่มสร้าง Svelte project กันดีกว่าครับ

  1. ขั้นแรกสำหรับใครที่ยังไม่เคยติดตั้ง node js สามารถดาวน์โหลดที่ node js
svelte install : node js download
node js

2. สร้างโปรเจ็ค Svelte ใน Visual code เริ่มจากการเปิด Termianl ใน VS ก่อน คลิ๊กที่ View บน Tabbar ตามด้วย Terminal

Svelte open terminal
เปิด Terminal ใน VS

3. พิมพ์ใน Terminal เพื่อติดตั้ง Svelte พร้อมตั้งชื่อ Project

npx degit sveltejs/template project-name

4. ทำการ change directory ไปที่ไฟล์ Project ที่สร้างไว้

cd .\project-name\

5. ติดตั้ง Dependencies อื่นๆใน ไฟล์ package.json

npm install

6. โฟลเดอร์ node-module จะปรากฏขึ้นมาใน โฟลเดอร์ Project ที่เราสร้างไว้

Svelte project
Svelte project

7. run application

npm run dev

8. เปิด Website ขึ้นมา ด้วยการ Ctrl+Click ที่ Local link

Svelte run app 300w" data-lazy-sizes="(max-width: 374px) 100vw, 374px" data-lazy-src="https://www.designil.com/wp-content/uploads/2021/06/image-3.png" data-ll-status="loaded" />
Your application is ready

9. ซึ่งจะปรากฏประโยคที่เราคุ้นเคยกันอย่าง Hello world ขึ้นมาบนจอ

Svelte Hello World 300w, 768w" data-lazy-sizes="(max-width: 610px) 100vw, 610px" data-lazy-src="https://www.designil.com/wp-content/uploads/2021/06/image-6.png" data-ll-status="loaded" />
Hello World!!!

การเขียนพวก State, Method , หรือพวก Event ต่างๆ จะเขียนใน


   
อ้างอิง
แบ่งปัน:
1,327,584 views since 16 August 2018