स्टेट मैनेजमेंट
परिचय
स्टेट मैनेजमेंट आपको पूरे पेज को फिर से बनाए बिना अपने UI के विशिष्ट भागों को अपडेट करने देता है। Nylo Website v7 में, आप ऐसे विजेट्स बना सकते हैं जो आपके पूरे ऐप में संवाद करते हैं और एक-दूसरे को अपडेट करते हैं।
Nylo Website स्टेट मैनेजमेंट के लिए दो क्लासेस प्रदान करता है:
NyState— पुन: प्रयोज्य विजेट्स बनाने के लिए (जैसे कार्ट बैज, नोटिफ़िकेशन काउंटर, या स्टेटस इंडिकेटर)NyPage— आपके एप्लिकेशन में पेज बनाने के लिए (NyStateको पेज-विशिष्ट सुविधाओं के साथ एक्सटेंड करता है)
स्टेट मैनेजमेंट का उपयोग करें जब आपको:
- अपने ऐप के किसी अन्य भाग से विजेट अपडेट करना हो
- साझा डेटा के साथ विजेट्स को सिंक में रखना हो
- UI का केवल एक भाग बदलने पर पूरे पेज को फिर से बनाने से बचना हो
पहले स्टेट मैनेजमेंट को समझते हैं
Flutter में सब कुछ एक विजेट है, ये UI के छोटे-छोटे टुकड़े हैं जिन्हें आप एक पूरा ऐप बनाने के लिए जोड़ सकते हैं।
जब आप जटिल पेज बनाना शुरू करते हैं, तो आपको अपने विजेट्स के स्टेट को मैनेज करने की आवश्यकता होगी। इसका मतलब है कि जब कुछ बदलता है, जैसे डेटा, तो आप पूरे पेज को फिर से बनाए बिना उस विजेट को अपडेट कर सकते हैं।
इसके कई कारण हैं कि यह महत्वपूर्ण है, लेकिन मुख्य कारण प्रदर्शन है। यदि आपके पास एक विजेट है जो लगातार बदल रहा है, तो आप हर बार बदलने पर पूरे पेज को फिर से नहीं बनाना चाहेंगे।
यहीं स्टेट मैनेजमेंट काम आता है, यह आपको अपने एप्लिकेशन में किसी विजेट के स्टेट को मैनेज करने की अनुमति देता है।
स्टेट मैनेजमेंट कब उपयोग करें
आपको स्टेट मैनेजमेंट का उपयोग तब करना चाहिए जब आपके पास कोई विजेट हो जिसे पूरे पेज को फिर से बनाए बिना अपडेट करने की आवश्यकता हो।
उदाहरण के लिए, मान लीजिए आपने एक ई-कॉमर्स ऐप बनाया है। आपने यूज़र के कार्ट में आइटम्स की कुल संख्या प्रदर्शित करने के लिए एक विजेट बनाया है।
इस विजेट को Cart() कहते हैं।
Nylo में एक स्टेट मैनेज्ड Cart विजेट कुछ इस तरह दिखेगा:
चरण 1: एक स्थिर स्टेट नाम के साथ विजेट परिभाषित करें
/// The Cart widget
class Cart extends StatefulWidget {
Cart({Key? key}) : super(key: key);
static String state = "cart"; // Unique identifier for this widget's state
@override
_CartState createState() => _CartState();
}
चरण 2: NyState को एक्सटेंड करते हुए स्टेट क्लास बनाएँ
/// The state class for the Cart widget
class _CartState extends NyState<Cart> {
String? _cartValue;
_CartState() {
stateName = Cart.state; // Register the state name
}
@override
get init => () async {
_cartValue = await getCartValue(); // Load initial data
};
@override
void stateUpdated(data) {
reboot(); // Reload the widget when state updates
}
@override
Widget view(BuildContext context) {
return Badge(
child: Icon(Icons.shopping_cart),
label: Text(_cartValue ?? "1"),
);
}
}
चरण 3: कार्ट पढ़ने और अपडेट करने के लिए हेल्पर फ़ंक्शन बनाएँ
/// Get the cart value from storage
Future<String> getCartValue() async {
return await storageRead(Keys.cart) ?? "1";
}
/// Set the cart value and notify the widget
Future setCartValue(String value) async {
await storageSave(Keys.cart, value);
updateState(Cart.state); // This triggers stateUpdated() on the widget
}
इसे समझते हैं।
-
Cartविजेट एकStatefulWidgetहै। -
_CartStateNyState<Cart>को एक्सटेंड करता है। -
आपको
stateके लिए एक नाम परिभाषित करना होगा, इसका उपयोग स्टेट की पहचान के लिए किया जाता है। -
boot()मेथड तब कॉल होता है जब विजेट पहली बार लोड होता है। -
stateUpdate()मेथड्स यह संभालते हैं कि स्टेट अपडेट होने पर क्या होता है।
यदि आप इस उदाहरण को अपने Nylo Website प्रोजेक्ट में आज़माना चाहते हैं, तो Cart नाम का एक नया विजेट बनाएँ।
metro make:state_managed_widget cart
फिर आप ऊपर दिए गए उदाहरण को कॉपी करके अपने प्रोजेक्ट में आज़मा सकते हैं।
अब, कार्ट अपडेट करने के लिए, आप निम्नलिखित कॉल कर सकते हैं।
_updateCart() async {
String count = await getCartValue();
String countIncremented = (int.parse(count) + 1).toString();
await storageSave(Keys.cart, countIncremented);
updateState(Cart.state);
}
लाइफ़साइकिल
NyState विजेट का लाइफ़साइकिल इस प्रकार है:
-
init()- यह मेथड स्टेट के इनिशियलाइज़ होने पर कॉल होता है। -
stateUpdated(data)- यह मेथड स्टेट अपडेट होने पर कॉल होता है।यदि आप
updateState(MyStateName.state, data: "The Data")कॉल करते हैं, तो यह stateUpdated(data) को ट्रिगर करेगा।
एक बार स्टेट पहली बार इनिशियलाइज़ हो जाने के बाद, आपको यह लागू करना होगा कि आप स्टेट को कैसे मैनेज करना चाहते हैं।
स्टेट एक्शन्स
स्टेट एक्शन्स आपको अपने ऐप में कहीं से भी किसी विजेट पर विशिष्ट मेथड्स ट्रिगर करने देते हैं। इन्हें नामित कमांड्स समझें जो आप किसी विजेट को भेज सकते हैं।
स्टेट एक्शन्स का उपयोग करें जब आपको:
- किसी विजेट पर एक विशिष्ट व्यवहार ट्रिगर करना हो (सिर्फ रिफ्रेश नहीं)
- किसी विजेट को डेटा पास करना हो और उसे एक विशेष तरीके से प्रतिक्रिया करवानी हो
- पुन: प्रयोज्य विजेट व्यवहार बनाने हों जो कई स्थानों से इनवोक किए जा सकें
// Sending an action to the widget
stateAction('hello_world_in_widget', state: MyWidget.state);
// Another example with data
stateAction('show_high_score', state: HighScore.state, data: {
"high_score": 100,
});
अपने विजेट में, आप उन एक्शन्स को परिभाषित कर सकते हैं जिन्हें आप हैंडल करना चाहते हैं।
...
@override
get stateActions => {
"hello_world_in_widget": () {
print('Hello world');
},
"reset_data": (data) async {
// Example with data
_textController.clear();
_myData = null;
setState(() {});
},
};
फिर, आप अपने एप्लिकेशन में कहीं से भी stateAction मेथड कॉल कर सकते हैं।
stateAction('hello_world_in_widget', state: MyWidget.state);
// prints 'Hello world'
User user = User(name: "John Doe", age: 30);
stateAction('update_user_info', state: MyWidget.state, data: user);
आप अपने init गेटर में whenStateAction मेथड का उपयोग करके भी अपने स्टेट एक्शन्स परिभाषित कर सकते हैं।
@override
get init => () async {
...
whenStateAction({
"reset_badge": () {
// Reset the badge count
_count = 0;
}
});
}
NyState - स्टेट एक्शन्स
सबसे पहले, एक stateful विजेट बनाएँ।
metro make:stateful_widget [widget_name]
उदाहरण: metro make:stateful_widget user_avatar
यह lib/resources/widgets/ डायरेक्टरी में एक नया विजेट बनाएगा।
यदि आप वह फ़ाइल खोलते हैं, तो आप अपने स्टेट एक्शन्स परिभाषित कर पाएँगे।
class _UserAvatarState extends NyState<UserAvatar> {
...
@override
get stateActions => {
"reset_avatar": () {
// Example
_avatar = null;
setState(() {});
},
"update_user_image": (User user) {
// Example
_avatar = user.image;
setState(() {});
},
"show_toast": (data) {
showSuccessToast(description: data['message']);
},
};
अंत में, आप अपने एप्लिकेशन में कहीं से भी एक्शन भेज सकते हैं।
stateAction('reset_avatar', state: MyWidget.state);
// prints 'Hello from the widget'
stateAction('reset_data', state: MyWidget.state);
// Reset data in widget
stateAction('show_toast', state: MyWidget.state, data: "Hello world");
// shows a success toast with the message
NyPage - स्टेट एक्शन्स
पेज भी स्टेट एक्शन्स प्राप्त कर सकते हैं। यह तब उपयोगी है जब आप विजेट्स या अन्य पेज से पेज-स्तरीय व्यवहार ट्रिगर करना चाहते हैं।
सबसे पहले, अपना स्टेट मैनेज्ड पेज बनाएँ।
metro make:page my_page
यह lib/resources/pages/ डायरेक्टरी में MyPage नाम का एक नया स्टेट मैनेज्ड पेज बनाएगा।
यदि आप वह फ़ाइल खोलते हैं, तो आप अपने स्टेट एक्शन्स परिभाषित कर पाएँगे।
class _MyPageState extends NyPage<MyPage> {
...
@override
bool get stateManaged => true;
@override
get stateActions => {
"test_page_action": () {
print('Hello from the page');
},
"reset_data": () {
// Example
_textController.clear();
_myData = null;
setState(() {});
},
"show_toast": (data) {
showSuccessToast(description: data['message']);
},
};
अंत में, आप अपने एप्लिकेशन में कहीं से भी एक्शन भेज सकते हैं।
stateAction('test_page_action', state: MyPage.state);
// prints 'Hello from the page'
stateAction('reset_data', state: MyPage.state);
// Reset data in page
stateAction('show_toast', state: MyPage.state, data: {
"message": "Hello from the page"
});
// shows a success toast with the message
आप whenStateAction मेथड का उपयोग करके भी अपने स्टेट एक्शन्स परिभाषित कर सकते हैं।
@override
get init => () async {
...
whenStateAction({
"reset_badge": () {
// Reset the badge count
_count = 0;
}
});
}
फिर आप अपने एप्लिकेशन में कहीं से भी एक्शन भेज सकते हैं।
stateAction('reset_badge', state: MyWidget.state);
स्टेट अपडेट करना
आप updateState() मेथड कॉल करके स्टेट अपडेट कर सकते हैं।
updateState(MyStateName.state);
// or with data
updateState(MyStateName.state, data: "The Data");
इसे आपके एप्लिकेशन में कहीं से भी कॉल किया जा सकता है।
यह भी देखें: NyState स्टेट मैनेजमेंट हेल्पर्स और लाइफ़साइकिल मेथड्स के बारे में अधिक जानकारी के लिए।
अपना पहला विजेट बनाना
अपने Nylo प्रोजेक्ट में, एक नया विजेट बनाने के लिए निम्नलिखित कमांड चलाएँ।
metro make:stateful_widget todo_list
यह TodoList नाम का एक नया NyState विजेट बनाएगा।
नोट: नया विजेट
lib/resources/widgets/डायरेक्टरी में बनाया जाएगा।