วิธีการใช้ FutureBuilder ใน flutter

ใน flutter ส่วนหน้า ui ทั้งหมดจะถูกสร้างจาก function build ซึ่ง function นี้จะถูกบังคับให้ implements จากการที่เราไป extends StatelessWi...



ใน flutter ส่วนหน้า ui ทั้งหมดจะถูกสร้างจาก function build ซึ่ง function นี้จะถูกบังคับให้ implements จากการที่เราไป extends StatelessWidget หรือ State ในกรณีที่ต้องการทำเป็น StatefulWidget
ในการทำงานของ function build นั้นจะต้อง return widget ออกมาซึ่ง function นี้จะถูกเรียกใช้เพื่อวาดหน้าจอเรา
แล้ว future function คืออะไร ใน flutter มันคือ function app asynchronous เทียบเท่า Promise ของ javascript นะครับโดยหน้าตา function เขาก็จะประมาณนี้
Future<bool> loadList() async {
    await sqlite.open("todo.db");
    activeTodo = await sqlite.listTodo(_tabIndex);
    return true;
}
จากตัวอย่าง code ด้านบนเป็นการดึงข้อมูลจาก sqlite มาใช้งานนะครับโดยการดึงข้อมูลนั้นเราจะดึงแบบ async แต่ตอน open database เราจะใช้ await เพื่อรอให้ open database ให้เสร็จก่อน
จากตัวอย่าง function นี้ถ้าในโจทย์ของโปรแกรมที่เราจะพัฒนานั้นมีการต้องดึงข้อมูลจาก list ออกมาให้เสร็จเสียก่อนแล้วถึงจะวาดหน้าจอเช่นจะใช้ ListView แสดงผลจากตัวแปร activeTodo ที่เป็น List ใน flutter เราต้องทำการ check ก่อนว่า activeTodo เป็น null หรือเปล่าเพราะถ้าเป็น null หรือข้อมูลยังไม่มีเราจะให้แสดงผลเป็น CircularProgressIndicator หรือตัววงกลมหมุนๆ
ถ้าโจทย์เป็นแบบนี้ก็มีหลายแนวทางในการเขียนแต่ในบทความนี้จะขอนำเสนอตัว class FutureBuilder เพื่อมาช่วยแก้ปัญหาโจทย์นี้ของเรากันนะครับ
วิธีการใช้ FutureBuilder นั้นต้องส่งค่า properties ไป 2 ตัวคือ future, builder โดย future call future function ส่วน builder เป็น function ที่เราต้องทำการ implements เขาไปโดย function นี้จะส่ง parameter มาให้ 2 ตัวคือ BuildContext, AsyncSnapshot
....
body: FutureBuilder(
    future: loadList(),
    builder: (BuildContext context, AsyncSnapshot snapshot) {
        if (snapshot.hasData) {
            return buildList();
        } else {
            return Center(
                child: CircularProgressIndicator(),
            );
        }
    },
),
....
จากตัวอย่าง code ด้านบนเราจะมีการเขียน check จาก AsyncSnapshot ก่อนว่ามีข้อมูลแล้วหรือยัง ถ้ายังไม่มีข้อมูลก็ให้แสดงผลเป็น CircularProgressIndicator ถ้ามีข้อมูลแล้วให้เรียก function buildList ซึ่ง function นี้ก็จะ return ออกมาเป็น widget เพื่อมาแสดงผลต่อไป
ในตัว flutter เองยังมี builder อื่นๆ อีกหลายตัวที่ทาง flutter เตรียมเอาไว้ให้นำไปใช้งานซึ่งในแต่ละตัวก็จะเหมาะกับแต่ละงานแตกต่างกันไป สำหรับท่านใดที่ลองทำตามแล้วไม่ได้ หรือว่าติดขัดอย่างไรสามารถเข้ามาพูดคุยแลกเปลี่ยนกันได้ที่ facebook : pnpsolutionหรือ web site : www.pnpsw.com ได้ครับ

COMMENTS

ชื่อ

การตลาดออนไลน์,5,กิจกรรม,1,บทความ,1,ประชาสัมพันธ์,6,วิธีใช้งาน cPanel,2,วิธีใช้งาน FTP,1,วิธีใช้งาน Manage,1,หารายได้ด้วยเว็บไซต์,2,Blogger,1,cloud,3,CodeGuard,1,Database Security,1,Data Security and Privacy,1,Design,3,development,3,Facebook,1,hosting,11,HTML,3,IT Competition,2,IT Knowledge,21,linux,1,MongoDB,1,Network Security,2,Photoshop,1,php,1,Plugin,1,Products,1,professional websites,3,Security,5,SEO,4,Theme WordPress,1,Threats Update,3,Vulnerability and Risk Management,3,Web Security,3,website,12,Website Builder,3,website building toos,3,Weebly,1,WordPress,5,
ltr
item
Peedam Hosting Blog : อุทยานแห่งการเรียนรู้ด้านเว็บไซต์: วิธีการใช้ FutureBuilder ใน flutter
วิธีการใช้ FutureBuilder ใน flutter
https://1.bp.blogspot.com/-tao_gRu5UJY/XVo0yRK-bZI/AAAAAAAAQPk/B72OyU4KTF0SKMmHvMbAKPgYDeymtD0OACLcBGAs/s640/1_PNjs7J4OzEjjKGyKf6FW1Q.png
https://1.bp.blogspot.com/-tao_gRu5UJY/XVo0yRK-bZI/AAAAAAAAQPk/B72OyU4KTF0SKMmHvMbAKPgYDeymtD0OACLcBGAs/s72-c/1_PNjs7J4OzEjjKGyKf6FW1Q.png
Peedam Hosting Blog : อุทยานแห่งการเรียนรู้ด้านเว็บไซต์
https://blog.peedamhosting.com/2019/08/futurebuilder-flutter.html
https://blog.peedamhosting.com/
https://blog.peedamhosting.com/
https://blog.peedamhosting.com/2019/08/futurebuilder-flutter.html
true
8681631110740510278
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy