-
អ្វីទៅជា Bloc State Management នៅក្នុង Flutter?Flutter 2021. 9. 6. 12:24반응형
ជា challenge ដ៍ ធំ សម្រាប់ ខ្ញុំ នៅពេល ដែល ចូល មក ធ្វើ ជាមួយ Flutter ហើយ ចូល មក គេ អោយ ធ្វើ ជាមួយនឹង Statement Management តែម្ដង. ខ្ញុំ បាន ព្យាយាម រក Sample code ដើម្បី យក មក ធ្វើការ ឈ្វែ ង យល់ បន្ថែម ប៉ុន្តែ នៅក្នុង Document និយាយ តែ ពី ចំណុច សំខាន់ នឹង មើល ទៅ ហាក់បីដូចជា យើង នឹង ជា Flutter Expert បាត់ ទៅ ហើយ. មាន ចំណុច ជាច្រើន ដែល ខ្ញុំ មើល យ៉ាងណា ក៍ នៅតែ មិន យល់. នៅ ពេល ខ្ញុំ ទៅ សួរ គេ គេ ប្រាប់ ថា ប្រើ getx, ឬ Provider, MobX ធ្វើអោយ ខ្ញុំ កាន់តែ វង្វេង ជាមួយ វា ហើយ មិនដឹងជា រៀន ប្រើ មួយ ណា.ដើម្បី ជា ជំនួយ ជួយ ដល់ អ្នក Beginners ថ្ងៃនេះ ខ្ញុំ នឹង មក ចែ ល រំលែក ខ្លះ ជាមួយ ជំហាន ដែល ត្រូវ រៀន នឹង ត្រូវ យល់ មុនគេ មុននឹង ចូល ទៅ សរ សេ កូដ ដោយ ប្រើ BLoc សម្រាប់ ការ ប្រើ ប្រាប់ ជា Statement Management.នៅក្នុង Flutter វា ពិតជា អាច ទៅរួច ដែល យើង សរ សេ កូដ យ៉ាង ច្រើន នៅក្នុង File តែមួយ មាន ទាំង Logic ផង មាន ទាំង UI បើ យើង ធ្វើ ដូច ច្នេះ យើង ពិតជា ពិបាក យល់ ណាស់ ពីព្រោះ Code ចេះតែ ច្រើន ទៅ ៗ ករណី ខ្លះ យើង ចង់ សរ សេ កូ ួ ដ សម្រាប់ Test Logic function របស់ យើង ដើរ ត្រូវ ឬ អត់ ប្រសិនបើ គ្មាន Statement យើង នឹង លំបាក ឬ មិនបាន តែម្ដង. ដើម្បី អាច សរ សេ Bloc បាន យើង ត្រូវ យល់ថា តើ State Management គឺជា អ្វី?អ្វីទៅជា State Management?
State Management
អ្វីទៅជា State?
State គឺជា
representation
គឺចង់សំដៅទៅលើការផ្ទុកទុសាចឋ data ាៅកនសំនួរ មួយទៀត ដែល ខ្ញុំ ឆ្ល ល់ ថា ចុះបើ Flutter បង្កើត មក ហើយ នៅ ចាំបាច់ ប្រើ State Management អី ទៀត?
Management State
ភាគច្រើន គេ ប្រើ សម្រាប់ the App ធំ ៗ ស្មុ ញ ស្មាញ បើ យើង the App តូច មិនបាច់ ក៍ បាន ដែរ
😅
.
អ្វីទៅជា Bloc?
ពាក្យ ពេញ មកពី bloc
the Business Logic Components
វា ប្រើ សម្រាប់ បំបែក the Business Logic UI ចេញពី និង ផ្ដល់ ភាព ងាយស្រួល សម្រាប់ ធ្វើការ Testing the Performance ក៍ ដូច ជួយ ដល់ the App របស់ យើង ផង ដែរ. ដើម្បីអោយ ទាំង គ្នា យល់ កាន់តែ ច្បាស់ តោះ ទៅ មើល ឧទាហរណ៍ ជាមួយ ខ្ញុំ ដែល យើង នឹង បង្កើត Counter App មួយ. ដើម្បី អនុវត្តន៍ តាម អត្ថបទ របស់ យើង ចូរ បង្កើត Flutter Project ថ្មី មួយ ដែល អ្នក អាច ដាក់ឈ្មោះ អ្វី ក៍ បាន ស្រា ច់ ចិត្ត. ដំបូង យើង the Add Library របស់ Bloc ត្រូវ ជា ចូល នៅក្នុ
pubspec.yaml
របស់ យើង ជាមុន សិន. បើក Terminal រួច run command ខាងក្រោម
ដើម្បីអោយ ទាំង គ្នា យល់ កាន់តែ ច្បាស់ តោះ ទៅ មើល ឧទាហរណ៍ ជាមួយ ខ្ញុំ ដែល យើង នឹង បង្កើត Counter App មួយ. ដើម្បី អនុវត្តន៍ តាម អត្ថបទ របស់ យើង ចូរ បង្កើត Flutter Project ថ្មី មួយ ដែល អ្នក អាច ដាក់ឈ្មោះ អ្វី ក៍ បាន ស្រា ច់ ចិត្ត. ដំបូង យើង the Add Library របស់ Bloc ត្រូវ ជា ចូល នៅក្នុ
pubspec.yaml
របស់ យើង ជាមុន សិន. បើក Terminal រួច run command ខាងក្រោម
flutter pub add flutter_bloc flutter pub get
ដើម្បី ផ្ដល់ ភាព ងាយ ស្រួ ូ ល ដល់ ការ បង្កើត Bloc សូម ត ម្លើ ង Plugin Bloc មួយ.
ចូលទៅក្នុង main.dart លុបកូដ Default
import bloc package ចូល
import 'package:flutter_bloc/flutter_bloc.dart';
Right click select យក Bloc Class option
បន្ទាប់ពីអ្នកចុច ok អ្នកនឹងទទដលបាន 3 files
- counter_bloc ជាកន្លែងសរសេ logic
- couter_event ជាកន្លែង Event មានន័យថា ឧទាហរហ៍ user click button នោះហហហហហ
- កំណត់ State អោយ the App ទៅ ជា កន្លែង counter_state របស់ ដែល យើង ឧទាហរណ៍ នៅពេល the Click User យើង ចង់ អោយ លេ កើន ពី 1 ទៅ 2 ដូច្នេះ យើង ត្រូវ បង្កើត the Event IncrementEvent នៅក្នុង Bloc យើង នឹង Check មើល ថា តើ User ត្រូវការ the Event មួយ ណា បន្ទាប់មក bloc គណនា Logic ផ្សេង ៗរួចអស់ហើយ bloc ត្រូវ Return state ដើម្បីអោយ UI render
- counter_event.dart
IncrementEvent ប្រើដើម្បី បូក number កើនឡើងថែមមួយរហូត
DecrementEvent ប្រើដើម្បី ដក number កើនឡើងថែមមួយរហូត
2.counter_state.dart
Default វា មាន ជា. Abstract, class CounterEvent
តែ យើង អាច The Remove ចេញ សិន ដើម្បី ភាព ងាយស្រួល មាន ពី ក្នុង ការ យល់ Bloc.
រួចបន្ថែមកូដខាងក្រោមដើម្បី៘ចព៘ល៘ល៘final int counter; const CounterState({@required this.counter}); 3. counter_bloc.dart នៅក្នុង Bloc មាន default ជាmapEventToState
ប្រើ ដើម្បី Check ថា បាន User ប្រើប្រាស់ the Event ណា មួយ ដោយ State រួច return នៅក្នុង bloc គេ ប្រើ (
yield
)
main.dart នៅក្នុង file main.dart យើង បាន សង្កេតមើល ឃើញថា យើង មាន ចំនុច 3 ដែល ថ្មី និង ទាក់ទង នឹង Bloc គឺ:1. BlocProvider
home: BlocProvider<CounterBloc>( create: (context) => CounterBloc(), child: Home(), ),
BlocProvider គឺជា Widget មួយ ដែល ប្រើ សម្រាប់ ផ្ដល់ Bloc ទៅ ប្រើប្រាស់ នៅក្នុង child របស់ វា តាមរយៈ BlocProvider.of <T> (context).
អ្វីដែលសំខាន់បំផុត BlocProvider ប្រើសម្រាប់បង្កើត Bloc និង dispose bloc ដោយ automatic.
2. BlocBuilder
BlocBuilder<CounterBloc, CounterState>( builder: (context, state) { return Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Text( 'You have pushed the button this many times:', ), Text( state.counter.toString(), style: Theme.of(context).textTheme.headline4, ), ], ), ); }, )
BlocBuilder
ជាកន្លែង Render UI អាស្រ័យទៅលើ currentState. ហើយ State ខ្លះអាចមាន Data មកជាមួយ ដូចក្នុាងខង Example ខចុងក្រោយ នេះ ជា កន្លែង Add Event នៅពេល ដែល យើង ចង់ ធ្វើ Action អ្វីមួយ យើង ត្រូវ Add Event ហើយ Event ទាំងនោះ គឺជា Event ដែល យើង ជា អ្នក បង្កើត ឡើង មក ខ្លួនឯង.BlocProvider.of<CounterBloc>(context).add(IncrementEvent());
សេចក្ដីសនាដ្ឋាន
យើង មាន មើលឃើញ ឧទារ ហ៍ ខាងលើ នូវ ដូចដែល យើង យល់ បាន ពី ក្នុង មូលដ្ឋាន ការប្រើប្រាស់ Bloc State Management ដើម្បី គ្រប់គ្រង State និង ផ្ដាច់ the Business Logic ចេញពីUI App របស់ យើង.
반응형'Flutter' 카테고리의 다른 글
ថ្នាក់ Flutter បង្កើត App សម្រាប់ IOS, Android និង Web (0) 2022.05.06 អ្វីទៅជា Flutter? (0) 2022.02.24 Flutter Push Notification for IOS and Android Free Soruce Code (0) 2022.01.18 Flutter Fetching Data From the API using BLoc (0) 2021.09.12