Github Page with Vue.js

Github มี service หนึ่งสำหรับการสร้างหน้าเว็บแบบง่ายๆ โดยจัดการผ่าน github repo ใครก็สามารถเข้าไปสร้างได้ โดยจะมีสองแบบคือ page หลัก และ subfolder หรือ repo ไหนก็ได้สามารถสร้างหน้า page ได้

Supphachoke Suntiwichaya
NECTEC
3 min readMay 17, 2020

--

ใครที่อยากมีหน้าเว็บแนะนำตัวง่ายๆ หรือแนะนำ project ก็เหมาะสมมาก หรือ ใครที่เขียนเว็บแล้วไม่มีที่ demo หรือจะอวดเพื่อนแต่ไม่มี hosting ให้วางก็ใช้ได้เช่นกัน แต่มีข้อจำกัดว่าเว็บต้องเป็น static เว็บที่มีพวก html, js, css และ รูปภาพต่าง หรือจะใช้ markdown เขียนทั้งหมดก็ได้ใครสนใจอ่านต่อได้ที่

สำหรับใครที่ยังเขียน Vue.js ไม่เป็นอ่านที่นี่ได้

User Page

หรือ page หลักของ account เราจะมี domain username.github.io ดังนั้น repo ที่จะสร้างก็ต้องใช้ชื่อตาม domain เลยถ้ายังไม่มี repo มาก่อนก็สามารถสร้างใหม่ และ จัดการผ่านเว็บของ github ได้เลยเช่นกัน

Create Repo

Click ที่ “+”
ตั้งชื่อ และ options

ตามที่บอกไปว่าให้เราตั้งชื่อ repo ตามชื่อ domain ที่เราใช้ของผมก็จะเป็น

และที่ต้องให้ความสนใจคือตรงสร้าง README ถ้าเราจะสร้างแบบใช้ Markdown เลยก็สร้าง README ตรงนี้ได้เลยเมื่อเข้าหน้าเว็บก็จะใช้ README เป็นหน้าเริ่มต้นทันที

สร้าง repo เสร็จแล้ว

Open Web Browser

หน้าแรก

ตอนนี้เราก็มีเว็บเป็นของตัวเองละ

ถ้าใครจะใช้ HTML เขียนก็แค่เปลี่ยนไปใช้ index.html แทน

Vue.js

แล้วถ้าเราจะใช้ Vue.js เป็นหน้าเว็บหลักของเราละ ? ทำได้เช่นกัน แต่เหมือนจะวุ่นๆ หน่อย โดยเฉพาะหน้าแรกจะมีข้อจำกัดหน่อย

  • สร้าง github repo ว่างๆ
  • สร้าง project vue.js หรือ ที่มีอยู่เดิม
  • build production ซึ่ง defualt จะได้ directory dist
  • เข้าไปใน dist แล้วสร้าง git repo ตามคำแนะนำของ github
เลือกแบบแรก
  • เลือกแบบแรก

ปัญหา

วิธีนี้มันมีปัญหาอยู่ว่าเมื่อเรา build production ใหม่ dist จะโดนลบทิ้งข้อมูล git จะโดนลบไปด้วยเราก็ต้อง backup ไว้

ครั้งต่อไปเมื่อเรา build production ก็ให้ copy ไปใส่อีกครั้ง

เราต้องทำแบบนี้ทุกครั้งที่มีการ update เฉพาะหน้าแรกนะที่ยุ่งยากแบบนี้

Repo Page

repo page คือ page ที่สร้างใน repo ต่างๆ ของเราเวลาเข้าถึงจะเรียกผ่าน

  • Create Github Repo
  • Create Vue.js Project
เลือกตัวเลือกที่สอง
  • เข้าไปใน vue.js project directory
  • เลือกตัวเลือกที่สองสำหรับเชื่อม repo

สร้าง vue.config.js

โดยเพิ่ม publicPath ให้ตรงกับชื่อ repo ของเรา แล้วทำการ commit

สร้าง branch ชื่อ gh-pages

แก้ไข .gitignore โดยการ comment /dist ไว้

save แต่ไม่ต้อง commit นะครับใช้ชั่วคราวเท่านั้น

Build Production

Git add dist

Git commit

Push Subtree ขึ้น Github repo

จะมี branch gh-pages เพิ่มมา

ตรวจสอบ Settings

เลือก Settings tab
ถ้ามี branch gh-pages จะถูกเลือกอัตโนมัติ

Open Web browser

เราก็จะได้ page ของ project แล้ว

Update Page

เมื่อเราจะ update Vue.js project ให้ทำดังนี้

git checkout ไปยัง master

แก้ .gitignore ให้กลับไปเหมือนเดิม

แก้ Vue.js Project

เมื่อพัฒนา Vue.js จน statble ก็ให้ทำการ commit

git checkout ไปยัง gh-pages

git merge master มา

comment /dist ใน .gitignore อีกครั้ง

Build Production

Git add dist

Git commit

Push Subtree ขึ้น Github repo

รอสักสักครู่หนึ่งให้ server update แล้วลอง reload หน้า page กูจะต้องเปลี่ยนแปลงตามที่เราแก้ไว้

Updated

ลองเอาไปเล่นกันดูครับ ผมคิดว่า project ที่ build เป็น static อื่นๆ ก็น่าจะใช้ได้ ไม่รวมพวก SSR นะครับ 😁

--

--