programming

The Understated Power of 0xf in Programming Realms

Have you ever come across the number 15, also known as

State Management in React

ဒီဆောင်းပါးမှာတော့ ကျနော်တို့ React app တစ်ခုမှာ State management ကို ဖြေရှင်းပေးတဲ့ Solution တချို့ကို ချဥ်းကပ်ကြည့်ကြပါမယ်။

Real-time Multi-player Terminal Game (Part - 2)

ဒီတစ်ခေါက်မှာတော့ ကျနော်တို့ Game Logic နဲ့ ပတ်သတ်တာတွေချည်းပဲ လုပ်သွားပါမယ်။

Real-time Multi-player Terminal Game (Part - 1)

ဒီ Tutorial မှာတော့ ကျနော်တို့ Terminal မှာ ကစားလို့ရတယ့် Game တစ်ခုတည်ဆောက်သွားပါမယ်။ အရင် Post မှာ Prologue ပြခဲ့တာကို တချက်ကြည့်ကြည့်ရင် ဘယ်လိုအလုပ်လုပ်လဲဆိုတာကို သိလောက်မှာပါ။ အဓိကကတော့

Web Sockets

ဒီတစ်ခေါက်မှာတော့ ကျနော်တို့ Web ပေါ်မှာ Real-time communication တွေလုပ်နိုင်ဖို့အတွက် အခြေခံအုတ်မြစ်ဖြစ်တဲ့ Web Socket အကြောင်းကို ပြောပြသွားမှာဖြစ်ပါတယ်။

Writing a Good Software Developer Résumé

Resume ကောင်းကောင်းရေးနိုင်ဖို့ကို ကျနော့် အတွေ့အကြုံကို အခြေခံပြီး ပြောပြသွားပါမယ်။ ကျနော့်လက်ရှိ Resume Style ကို ပြသွားမှာဖြစ်ပြီး ဘယ်လို Organize လုပ်ထားလဲ ဆိုတာကိုပဲ ပြောပြသွားမှာပါ။

EventLoop in Plain Burmese

JavaScript ကို လေ့လာနေသူတိုင်း Basic ကနေ နောက်တစ်ဆင့်ကို တက်တော့မယ်ဆိုရင် Event Loop အကြောင်းက ထိပ်ဆုံးကနေ ပါလာမှာပဲဖြစ်ပါတယ်။ ဒီဆောင်းပါးမှာတော့ JavaScript ရဲ့ Asynchronous Code တွေကို ဘယ်လို Execute လုပ်လဲ ၊ Event Loop ဆိုတာဘာလဲ စတာတွေကို ပြောပြသွားမှာဖြစ်ပါတယ်။

Designing a Good API

ဒီတစ်ခေါက်မှာတော့ ကျနော်တို့ API တစ်ခု တည်ဆောက်တဲ့အခါမှာ Design ‌‌‌ကောင်းတစ်ခု ဖြစ်ဖို့အတွက် လိုက်နာရမယ့် အချက်တွေကို ပြောပြသွားမှာ ဖြစ်ပါတယ်။

Synchronous, Asynchronous, Parallelism and Concurrency

ဒီတစ်ခေါက်မှာတော့ Execution Model တွေရဲ့ သဘောတရားတွေကို ဆွေးနွေးသွားမှာ ဖြစ်ပါတယ်။

What is 'use-strict' in JavaScript?

နောက်ထပ် Page မှာ အမေးများတဲ့ မေးခွန်းတစ်ခုဖြစ်တဲ့ "use-strict" ဆိုတာဘာလဲဆိုတာကို ပြောပြသွားမှာဖြစ်ပါတယ်။

Where to Host your Project?

ကျနော့်ကို လာလာပြီးမေးကြတဲ့မေးခွန်းတွေထဲက အမေးအများဆုံးမေးခွန်းတစ်ခုဖြစ်တဲ့ "ဘယ်မှာ Host ရမလဲ ၊ deploy လုပ်ရမလဲ" ဆိုတာနဲ့ ပတ်သတ်ပြီးတော့ Project Type ပေါ်မူတည်ပြီး လက်ရှိမှာရွေးချယ်နိုင်တဲ့ option တွေနဲ့ ကျနော့်ရဲ့ အတွေ့အကြုံပေါ်အခြေခံပြီးတော့ ဘယ်ဟာကပိုပြီးအဆင်ပြေတယ် ဆိုတာတွေကို ‌ပြောပြသွားမှာဖြစ်ပါတယ်။

5. React Core Concepts

ဒီတစ်ခေါက်မှာတော့ React ကိုလေ့လာတဲ့အခါမှာ ကြုံလာရမယ့် Term တချို့နဲ့ သူတို့ဘာကိုဆိုလိုသလဲဆိုတာရယ် ၊ နောက်ပြီး သိထားသင့်တဲ့

Podcasts for Developers

Podcast နားထောင်ရတာဟာ သွားရင်လာရင်း ဖြစ်ဖြစ် ၊ အိပ်ခါနီးဖြစ်ဖြစ်လုပ်လို့ရတာဖြစ်တဲ့အတွက် အချိန်သိပ်မကုန်ပဲ ထိရောက်တဲ့ learning ပုံစံတစ်မျိုးဖြစ်ပါတယ်။ Developer တွေအတွက်လည်း Podcast နားထောင်တဲ့အခါမှာ industry ရဲ့ insight တွေကိုမြင်စေနိုင်တဲ့အပြင် ၊ တချို့ episode တွေမှာလာတဲ့ အကြောင်းအရာတွေဟာ အလွန်စိတ်ဝင်စားဖို့ကောင်းပါတယ်။ ပြီးတော့ တချို့guest တွေရဲ့ ပြောဆိုပုံကနေ သူတို့ရဲ့ passion နဲ့ capability ကို မှန်းမြင်နိုင်တဲ့အတွက် coding လေ့လာတဲ့နေရာမှာ motivate ပိုပြီးဖြစ်စေပါတယ်။ ဘာလို့လဲဆိုတော့ Coding လေ့လာတဲ့နေရာမှာ တွေ့ရတဲ့ပြဿနာတစ်ခုက motivation လမ်းခုလတ်မှာပျောက်ဆုံးတာဖြစ်ပြီး သိတဲ့ tech stack နဲ့ပဲ လှေနံဓားထစ်ချည်း ဆက်သွားနေတာမျိုးတွေဖြစ်တတ်ပါတယ်။ ဒါ့ကြောင့် ကျနော် ရံဖန်ရံခါနားထောင်လေ့ရှိတဲ့ထဲက ကောင်းမယ်ထင်တဲ့ Podcast တွေကို list လုပ်လိုက်ပါတယ်။

Containers (Under the Hood)

Container တွေအကြောင်းကို ပြီးခဲ့တဲ့ article မှာ မိတ်ဆက်အနေနဲ့ ပြောပြခဲ့ပြီးဖြစ်ပါတယ်။ ဒီတစ်ခေါက်မှာတော့ Container တွေရဲ့ Resource Isolation ကို လုပ်ပေးတဲ့ အရာတွေကို လက်တွေ့လေ့လာသွားမှာဖြစ်ပါတယ်။

Containers Intro

Developer တွေဟာ Software Development လုပ်နေရုံနဲ့ပြီးနေတာမဟုတ်ပဲ ကိုယ်ရေးတဲ့ software ကို ship လုပ်ဖို့လိုလာတဲ့တစ်ချိန်ချိန်မှာတော့ Software Deployment နဲ့ပတ်သက်ပြီး ကြုံတွေ့လာရတာပဲဖြစ်ပါတယ်။ ဒါ့ကြောင့် ဒီတစ်ခေါက်မှာတော့ လက်ရှိ Software Development & Deployment မှာအရေးအပါဆုံးဖြစ်နေတဲ့ Containerization ဆိုတဲ့ နည်းပညာအကြောင်းကို ပြောပြသွားမှာဖြစ်ပါတယ်။

4. Setting Up a React Project

ဒီတစ်ခေါက်မှာတော့ တကယ့် React Project တစ်ခုကို ဘယ်လို initiate လုပ်မလဲဆိုတာကိုပြောပြသွားမှာ ဖြစ်ပါတယ်။ Setup လုပ်ဖို့ကတော့ အဓိကအားဖြင့်တော့ နှစ်မျိုးရှိပါတယ်။ create-react-app လို့ခေါ်တဲ့ tool ကိုပဲသုံးပြီး project ဆောက်မလား ၊ ကိုယ်ကိုယ်တိုင်ပဲ လိုအပ်သလို configuration တွေနဲ့ project setup လုပ်မလားပေါ့။ ပုံမှန်အားဖြင့်တော့ create-react-app နဲ့ လုပ်တာပိုကောင်းပါတယ်။ ဒါပေမယ့် နည်းနည်း experience ရှိလာရင်တော့ ကိုယ်တိုင် တည်ဆောက်ကြည့်သင့်ပါတယ်။ ဒီလိုလုပ်နိုင်ဖို့အတွက် ကျနော် setup လုပ်တဲ့ ပုံစံတစ်မျိုးကိုလည်း step-by-step လုပ်ပြသွားမှာဖြစ်ပါတယ်။

3. Getting Started

JavaScript Fundamentals တွေကိုလည်း သိပြီဆိုရင်တော့ ကျနော်တို့ React ကိုစပြီး လေ့လာလို့ရပါပြီ။ React ရဲ့ JSX ဘက်ကိုမလှည့်ခင်မှာ အရင်ဆုံးအနေနဲ့ ကျနော်တို့ Pure React ကိုပဲလေ့လာကြရအောင်။ ဘာလို့လဲဆိုတော့ ကျနော် React ကိုစလေ့လာတုန်းက JSX ကြီးကိုမြင်ရတာ တမျိုးကြီးဖြစ်နေခဲ့ပါတယ်။ ဘာလို့ HTML ကို JavaScript ထဲထည့်ရေးရမှာလဲ ၊ ဘာလို့ နောက်ထပ် Transpile လုပ်ပေးဖို့လိုတဲ့ extra language ကြီးလိုတာလဲပေါ့။ အမှန်တကယ်တော့ React App တစ်ခုဖြစ်ဖို့အတွက် JSX မလိုပါဘူး။ ဒါ့ကြောင့် ဒီတစ်ခေါက်ရဲ့ အဓိက point ကတော့ JSX ကဘာလို့ React ရဲ့ eco system အတွက် make sense ဖြစ်တာလဲ ၊ ပြီးတော့နောက်တစ်ခုက ဒီ JSX နဲ့ React က Magic တွေသုံးနေတာမဟုတ်ဘူး ၊ ပုံမှန် JavaScript ရဲ့ function call တဲ့ပုံစံတွေပဲဆိုတာကို အဓိကသိစေချင်တာဖြစ်ပါတယ်။

2. JS Things to Know Before React

React ကို စမလေ့လာခင်မှာ JavaScript နဲ့ပတ်သတ်ပြီး solid foundation ရှိဖို့တော့လိုပါတယ်။ ဒါဆို ဘာတွေကို အဓိက သိထားရမလဲပေါ့ ? အဲဒီအတွက် ကျနော် checklist လေးတစ်ခုလုပ်ထားပါတယ်။ အမှန်တကယ်တော့ ဘယ် JavaScript library / framework ကို လေ့လာလေ့လာ ဒီ checklist မှာပါတဲ့ topic တွေကတော့ သိထားသင့်တာတွေချည်းပဲဖြစ်ပါတယ်။

1. React Intro

React ဟာ လက်ရှိမှာ popular အဖြစ်ဆုံး ၊ အသုံးအများဆုံး JavaScript Frontend Library တစ်ခုဖြစ်ပါတယ်။ ဒီအကြောင်းပြချက်တစ်ခုနဲ့တင် React ကိုလေ့လာသင့်ပြီလို့ဆိုရမယ်ဆိုရင် မမှားပါဘူး။ ဒါပေမယ့်လည်း ရေရှည်မှာ ဒီအကြောင်းပြချက်တစ်ခုတည်းနဲ့တင် မလုံလောက်တော့ပါဘူး။ "ဘာ့ကြောင့်လဲ" ဆိုတဲ့မေးခွန်းဟာ လေ့လာသူတွေ တစ်စုံတစ်ခုကို လေ့လာတိုင်းမှာ အမြဲတစေမေးသင့်တဲ့ မေးခွန်းတစ်ခုပဲဖြစ်ပါတယ်။ JavaScript Library တွေဟာ အချိန်နဲ့အမျှ အသစ်သစ်တွေထွက်နေတာမို့ ကိုယ်လေ့လာနေတဲ့ Library ရဲ့ pros and cons တွေ ၊ unique value တွေ ၊ differences တွေ ၊ ဒီ library ရဲ့ နောက်က fundamental concept တွေ စတာတွေကို သိထားဖို့လိုအပ်ပါတယ်။

Queue

ဒီတစ်ခေါက်ရဲ့ data structure ကတော့ Queue လို့ခေါ်တဲ့ linear data structure တစ်ခုဖြစ်ပါတယ်။ Stack နဲ့ ခပ်ဆင်ဆင်ဖြစ်ပြီးတော့ မတူတာကတော့ သူက First-in-First-out (FIFO) ဖြစ်ပြီးတော့ Stack ကတော့ FILO ဖြစ်တာပါ။ ဥပမာပေးရမယ်ဆိုရင်တော့ Queue data structure ဟာ လူတွေ restaurant တွေရဲ့ service counter မှာတန်းစီရတာနဲ့တူပါတယ်။ အရင်ရောက်တဲ့သူကို အရင်ဆုံး serve ရတာမျိုးပါ။ Queue မှာ

Execution Context

JavaScript မှာ Code တွေကို internally ဘယ်လိုအလုပ်လုပ်ပြီး execute လုပ်လဲဆိုတဲ့အကြောင်းဖြစ်ပါတယ်။