data:image/s3,"s3://crabby-images/a89aa/a89aa79e11d39c1333dec509b947e5f063d99703" alt=""
What is Flutter
- Mobile Application Development Framework Developed by Google
- Uses the programming language Dart (also developed by Google)
data:image/s3,"s3://crabby-images/2d194/2d194cbd9fcb8ddef7eab41c2bd4e8eaf1917d09" alt=""
data:image/s3,"s3://crabby-images/ccf54/ccf5446582506268d14e96c6c4bbc288ff58a813" alt=""
- open source programming language developed by Google
- Object-oriented and similar in syntax to Java, C# and C++
Native
Unlike many other mobile frameworks, Flutter compiles your Dart ahead-of-time down to native code for each platform.
Hybrid App
data:image/s3,"s3://crabby-images/e36e3/e36e3eaef6e53b52aee83246d4d7e4a89f6ebdf4" alt=""
Javascript Hybrid
(ie React Native)
data:image/s3,"s3://crabby-images/e7f3d/e7f3d276a528c26a41dd26874848a5fee041e459" alt=""
Flutter
data:image/s3,"s3://crabby-images/3fd59/3fd590655b36876799aab3af096e217fc14c402c" alt=""
data:image/s3,"s3://crabby-images/14e70/14e702f8b591629b64e62437f69982b11bd756aa" alt=""
data:image/s3,"s3://crabby-images/80911/8091152e4a88cd0d98064843357f2b312179e6b5" alt=""
data:image/s3,"s3://crabby-images/ccf4a/ccf4a49748dae7b23889280b936aa081dc7d42e6" alt=""
hybrid
React Native
Flutter
Flutter composition
- Widgets
- Stateless
- Stateful
- BuildContext
Widgets
- A widget is a class that represents a specific functionality or feature within the app
- Different widgets for each layout element as well as properties for manipulating them
data:image/s3,"s3://crabby-images/7c933/7c9335dcb5f9804975869f08dccd848dda84f210" alt=""
data:image/s3,"s3://crabby-images/73ffc/73ffc08ef1ec5358ccbc55e221c91b24d6d855f9" alt=""
data:image/s3,"s3://crabby-images/cc607/cc607d2ad29aeaf820d8d8d5758eed122d47a1d6" alt=""
data:image/s3,"s3://crabby-images/bc166/bc16669df3906f98d46cb8872ffe4a2bb5b3ca86" alt=""
data:image/s3,"s3://crabby-images/a1ead/a1eadae33a7459711655cbde039bc69b72dc2a3d" alt=""
data:image/s3,"s3://crabby-images/a9ed4/a9ed49d652b70eb1ea569310e9245a64346ee342" alt=""
data:image/s3,"s3://crabby-images/d3166/d3166f2f8afec37799068a43efc7bed7c7633d8a" alt=""
data:image/s3,"s3://crabby-images/2fc90/2fc90e9371ca1b14d6f22539b2e1f6175d5137d1" alt=""
data:image/s3,"s3://crabby-images/6a38c/6a38c40d9e51ec1beacbec2015e13377a533621d" alt=""
data:image/s3,"s3://crabby-images/b8452/b84528f1b4004409337fe2f82427e754cc4e92fe" alt=""
hierarchical
Just like with web development, building a Flutter app consists of nesting elements inside one another.
Flutter doesn't use a templating language like HTML so you build the template by nesting classes.
STateLess Widget
A simple widget with properties that don't change
Describes part of the user interface by building a constellation of other widgets that describe the user interface more concretely
Can have stateful widgets nested inside
data:image/s3,"s3://crabby-images/a11c9/a11c9953b0de8220ee0dc93838dab908543204e7" alt=""
https://flutterdoc.com/stateful-or-stateless-widgets-42a132e529ed
StateFul
A more complex widget with properties that will change during it's life, due to user input or something else like data returned from an API call
data:image/s3,"s3://crabby-images/75296/752962d6491d455f754e4fa16f28e169c3434a1a" alt=""
data:image/s3,"s3://crabby-images/5fc1d/5fc1de90ab6527f0e79fa2696455ef538e78066e" alt=""
data:image/s3,"s3://crabby-images/f949f/f949f8e25225d0ca1e5d10a865b17ec42e84f52e" alt=""
data:image/s3,"s3://crabby-images/b6425/b6425a336b6956c3c7320aaf250a5c9a5527c2f2" alt=""
Build
All widgets need to override the build method. This method needs to return a Widget.
data:image/s3,"s3://crabby-images/cbaf5/cbaf58c6b2a8928cd9ddc700fbdf70554733555a" alt=""
Building a TODO List app
MaterialApp
Provides a comprehensive set of Material Design Widgets that we can use to easily scaffold our application
data:image/s3,"s3://crabby-images/c4d0c/c4d0cff7bd2a706789efd35da592668fb066f80b" alt=""
data:image/s3,"s3://crabby-images/b2b49/b2b499a6f8ff717b51e65b2ce35a45da214cc4a1" alt=""
data:image/s3,"s3://crabby-images/3a9f6/3a9f6efed05b101b0b91896533026f77a25cf961" alt=""
Main
main() is the entry point of a Dart Application. The Flutter framework gives us runApp(), the point of entry for our Flutter App.
data:image/s3,"s3://crabby-images/05e5c/05e5c163f2c5d418c9438be8b16a6dbfa2565d7a" alt=""
Our app is a stateless widget with stateful widgets nested inside.
If you need to keep track of any global variables, you should use a stateful Widget instead
Home Page
The Home page is a stateful widget that encompasses all other items in the app
data:image/s3,"s3://crabby-images/39531/395317bb2d4251b686f375ec3159af50236f8bc5" alt=""
data:image/s3,"s3://crabby-images/61567/61567d9140134d967e562c431a55db1ccf74ed7c" alt=""
Scaffold
A widget used to implement the basic material design visual layout structure
This class provides APIs for showing drawers, snack bars, and bottom sheets
data:image/s3,"s3://crabby-images/aa8e0/aa8e03c4021fe6b3255539411e3dc7ff0423974e" alt=""
data:image/s3,"s3://crabby-images/05825/05825c890cfe912abc60dac72b90085c796d2cf4" alt=""
data:image/s3,"s3://crabby-images/865b9/865b93516726ea9eb8702ef9686df8252118f45f" alt=""
Resources
Flutter
By Michael Busby
Flutter
- 1,636