ဒီစာဟာ လက်ရှိ Rockstar Developer Course မှာ တက်ရောက်နေသူတွေ အတွက်ဖြစ်တယ်။ ဒါကြောင့် အပြင်လူတွေ နားလည်စေမယ့် ရှင်းလင်းချက် အပြည့်အစုံနဲ့ အသေးစိတ်တော့ ပါမှာမဟုတ်ပါဘူး။ နောင်အချိန်ရမှ ထပ်ဖြည့်ပေးပါမယ်။
React က စမ်းသပ်နေတာ ကာလတစ်ခုကြာပြီဖြစ်တဲ့ Hooks လိုခေါ်တဲ့ Feature ကို React v16.8 မှာ စတင်ထည့်သွင်းပေးခဲ့ပါပြီ။ ဒါကြောင့် တို့တွေလည်း စတင်စမ်းသပ် အသုံးပြုသင့်ပြီဆိုပါတော့။ အဲ့ဒီ Hooks အကြောင်းကို ဒီနေရာမှာ ရှင်းပြသွားမှာပါ။
React မှာ State တွေကို စီမံဖို့ Class Component တွေကို သုံးရတယ်။ အကယ်၍ Functional Component တွေ သုံးချင်ရင်တော့ State တွေကို တိုက်ရိုက်စီမံလို့ ရမှာမဟုတ်ပဲ Redux လို နည်းပညာမျိုးရဲ့ အကူအညီကို ယူရမှာဖြစ်ကြောင်းကို လက်ရှိလေ့လာနေသူတိုင်း သိရှိကြပြီးသားပါ။ ဒါပေမယ့် စာနွှေးပြီးသား ဖြစ်သွားအောင် နမူနာတစ်ချို့ ပြန်ဖော်ပြပေးပါမယ်။
class App extends React.Component {
constructor() {
super()
this.state = {
data: [ 'one', 'two' ]
}
this.add = this.add.bind(this)
}
add() {
this.setState({
data: [ ...this.state.data, 'three' ]
})
}
render() {
return (
<div>
<ul>
{this.state.data.map(item => {
return <li>{item}</li>
})}
</ul>
<button onClick={this.add}>Add</button>
</div>
)
}
}
ဒါဟာ Class Component တစ်ခုဖြစ်ပြီး data
လို့ခေါ်တဲ့ State ပါဝင်တယ်။ နှိပ်လိုက်ရင် data
State မှာ တစ်ခုထပ်တိုးပေးတဲ့ add()
Method ပါဝင်တယ်။ ကူးယူစမ်းသပ်ဖို့ မဟုတ်ပဲ ဖတ်ရှုလေ့လာဖို့သာ ဖြစ်ပါတယ်။ အတက်နိုင်ဆုံး ကုဒ်ကိုတိုအောင်လျှော့ရေးထားလို့ မပြည့်စုံပါဘူး။ ဥပမာ - <li>
တွေမှာ key Attribute ပါဝင်သင့်ပေမယ့် ထည့်မထားသလို Button ကို ဘယ်နှစ်ကြိမ်နှိပ်နှိပ် data
State မှာ တိုးသွားမယ့် တန်းဖိုးက တစ်ခုတည်းပါ။ ဒါပေမယ့် အလုပ်လုပ်ပုံက အရေးမကြီးပါပဲ။ အရေးကြီးတာက Class Component တွေမှာ State တွေကို ဒီလိုစီမံတယ်ဆိုတဲ့ အချက်ကသာ အရေးကြီးတာပါ။ ဒီ Class ကို ပိုတိုသွားအောင် Class Field လို့ခေါ်တဲ့ ရေးထုံးသစ်နဲ့ ပြောင်းရေးပါဦးမယ်။
class App extends React.Component {
state = {
data: [ 'one', 'two' ]
}
add = () => {
this.setState({
data: [ ...this.state.data, 'three' ]
})
}
render() {
return (
<div>
<ul>
{this.state.data.map(item => {
return <li>{item}</li>
})}
</ul>
<button onClick={this.add}>Add</button>
</div>
)
}
}
constructor
မပါတော့ပဲ add()
ကိုလည်း Arrow Function အဖြစ် ပြောင်းလဲ ရေးသားလိုက်လို့ bind(this)
မလိုအပ်တော့ပါဘူး။ ကျန်တာတော့ အတူတူပါပဲ။ ဒီကုဒ်ကို Functional Component အဖြစ် ပြောင်းလဲရေးသားမယ်ဆိုရင် ဒီလို ရေးနိုင်ပါတယ်။
function App(props) {
return (
<div>
<ul>
{props.data.map(item => {
return <li>{item}</li>
})}
</ul>
</div>
)
}
/* OR */
const App = (props) => {
return (
<div>
<ul>
{props.data.map(item => {
return <li>{item}</li>
})}
</ul>
</div>
)
}
State ပါဝင်ခြင်းမရှိပဲ ဒီ Component ကို ခေါ်ယူစဉ် ထည့်သွင်းပေးတဲ့ props
ကိုသာ အသုံးပြုနိုင်မှာ ဖြစ်ပါတယ်။ ဥပမာ -
<App data={['one', 'two']} />
ဒါပေမယ့် Redux ရဲ့ အကူအညီ ယူလိုက်မယ်ဆိုရင်တော့ Functional Component တွေမှာလည်း State တွေ စီမံအသုံးပြုနိုင်သွားမှာပါ။
const App = (props) => {
return (
<div>
<ul>
{props.data.map(item => {
return <li>{item}</li>
})}
<button onClick={props.add}>Add</button>
</ul>
</div>
)
}
var ReduxApp = connect(state => {
return {
data: state.data
}
}, dispatch => {
return {
add: () => {
dispatch({ type: 'ADD' })
}
}
})(App)
var store = createStore(state = { data: ['one', 'two'] }, (action) => {
if(action.type === 'ADD') {
return {
data: [ ...state.data, 'three' ]
}
}
return state;
})
<Provider store={store}>
<ReduxApp />
</Provider>
"အလုပ်တွေရှုပ်လိုက်တာ" လို့ အခုမှလေ့လာတဲ့သူတွေ တွေးမှာသေချာပေမယ့်၊ Rockstar တန်းမှာ လက်ရှိတက်နေတဲ့သူတွေကတော့ ဒီနည်းကပေးတဲ့ အကျိုးရလဒ်ကို သိရှိကြပြီးဖြစ်ပါတယ်။ အခုတော့ အလားတူအကျိုးရလဒ်မျိုးကို အခုလိုရှုပ်ထွေးတဲ့ Redux ကနေ တစ်ဆင့်ခံနေစရာ မလိုတော့ပဲ Feature သစ်ဖြစ်တဲ့ Hooks ကို အသုံးပြုနိုင်တော့မှာပဲ ဖြစ်ပါတယ်။ အထက်မှာ ရေးခဲ့တဲ့ကုဒ်ကို Hooks အသုံးပြုပြီး အခုလို ရေးသားနိုင်မှာပါ။
const App = (props) => {
const [data, setData] = useState(['one', 'two']);
return (
<div>
<ul>
{data.map(item => {
return <li>{item}</li>
})}
<button onClick={() => {
setData([...data, 'three'])
}}>Add</button>
</ul>
</div>
)
}
ဒါပါပဲ။ ရေးထုံးအများကြီး ရိုးရှင်းသွားပါပြီ။ ဒီနေရာမှာ အသုံးပြုခဲ့တဲ့ Hooks Function က တစ်ခုတည်းပါ။ useState()
ဖြစ်ပါတယ်။ useState()
Function ဟာ ရလဒ်နှစ်ခုကို Return ပြန်ပေးပါတယ်။ ပထမတစ်ခုက State Data ဖြစ်ပြီး ဒုတိယတစ်ခုက အဲ့ဒီ State Data ကို စီမံနိုင်တဲ့ Function ပါ။ ပေးထားတဲ့ နမူနာမှာ data
ဟာ State Data ဖြစ်သွားပြီး setData
ကတော့ data ကို စီမံနိုင်တဲ့ Function ပေါ့။ ဒီ Function နဲ့ State ကို ပြောင်းလိုက်ရင် ထုံးစံအတိုင်း Component ကလည်း အလိုအလျှောက် လိုက်ပြောင်းပေးသွားမှာ ဖြစ်ပါတယ်။
useState()
အပြင် useEffect()
, useContext()
စတဲ့ တစ်ခြား Hook Function တွေ ရှိပါသေးတယ်။ ဒါတွေ အကြောင်းတော့ ခေါင်းစားမခံပါနဲ့ဦး။ useState()
ရဲ့ အကူအညီနဲ့ Functional Component တွေမှာ State ကို တိုက်ရိုက် စီမံအသုံးပြုလို့ ရတာနဲ့တင် အများကြီးအသုံးဝင်နေပါပြီ။
React နဲ့ပက်သက်တဲ့ တစ်ခြား အဆင့်မြင့်အကြောင်းအရာတွေဖြစ်တဲ့ Context တို့ Suspense တို့လို လုပ်ဆောင်ချက်တွေ ရှိပါသေးတယ်။ ဒါတွေအကြောင်းကို အခြေအနေပေးမယ်ဆိုရင် နောက်တော့မှ ထပ်ရှင်းပြပါဦးမယ်။
Thanks ဆရာ