Halo semuanya, kembali lagi di sahretech. Pada kesempatan kali ini kita akan belajar cara membuat dropdown select input di flutter secara cepat dan mudah. Penasaran?, ayo ikuti tutorialnya di bawah ini.
Baca Artikel Lain ✨ |
📰 1. Membuat Restful Api di Laravel Tanpa Library Tambahan Part 1 read more |
📰 2. Menampilkan Data dengan API dan Token di Laravel Part 2 read more |
📰 3. Cara Membuat Custom Registrasi dan Prosesnya di Laravel Part
1 read more |
📰 4. Cara Membuat Custom Login di Laravel Part 2 read more |
Cara Membuat Dropdown Select Input di Flutter
2. Buka lib/main.dart lalu ganti dengan script di bawah ini.
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Form Example',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyForm(),
);
}
}
class MyForm extends StatefulWidget {
@override
_MyFormState createState() => _MyFormState();
}
class _MyFormState extends State<MyForm> {
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
String? name;
String? gender;
String? religion;
String? education;
List<String> genderOptions = ['Male', 'Female'];
List<String> religionOptions = [
'Islam',
'Christianity',
'Catholicism',
'Hinduism',
'Buddhism'
];
List<String> educationOptions = [
'Elementary School',
'Junior High School',
'Senior High School',
'Bachelor',
'Master',
'Doctorate'
];
String result = '';
void _submitForm() {
if (_formKey.currentState!.validate()) {
_formKey.currentState!.save();
setState(() {
result =
'Name: $name\n\nGender: $gender\n\nReligion: $religion\n\nEducation: $education';
});
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Form Example'),
),
body: SingleChildScrollView(
padding: EdgeInsets.all(20.0),
child: Form(
key: _formKey,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
TextFormField(
decoration: InputDecoration(
labelText: 'Name',
),
validator: (value) {
if (value!.isEmpty) {
return 'Name cannot be empty';
}
return null;
},
onSaved: (value) {
name = value;
},
),
SizedBox(height: 20.0),
DropdownButtonFormField<String>(
decoration: InputDecoration(
labelText: 'Gender',
),
value: gender,
items: genderOptions.map((String value) {
return DropdownMenuItem<String>(
value: value,
child: Text(value),
);
}).toList(),
onChanged: (newValue) {
setState(() {
gender = newValue;
});
},
),
SizedBox(height: 20.0),
DropdownButtonFormField<String>(
decoration: InputDecoration(
labelText: 'Religion',
),
value: religion,
items: religionOptions.map((String value) {
return DropdownMenuItem<String>(
value: value,
child: Text(value),
);
}).toList(),
onChanged: (newValue) {
setState(() {
religion = newValue;
});
},
),
SizedBox(height: 20.0),
DropdownButtonFormField<String>(
decoration: InputDecoration(
labelText: 'Education',
),
value: education,
items: educationOptions.map((String value) {
return DropdownMenuItem<String>(
value: value,
child: Text(value),
);
}).toList(),
onChanged: (newValue) {
setState(() {
education = newValue;
});
},
),
SizedBox(height: 20.0),
ElevatedButton(
onPressed: _submitForm,
child: Text('Submit'),
),
SizedBox(height: 20.0),
Text(
result,
style: TextStyle(fontSize: 18.0),
),
],
),
),
),
);
}
}
Penjelasan Script di atas:
- import 'package:flutter/material.dart';: Baris ini mengimpor pustaka Flutter yang diperlukan untuk mengembangkan antarmuka pengguna.
- void main() { ... }: Fungsi main adalah fungsi utama yang pertama kali dijalankan saat aplikasi dimulai. Fungsi ini menjalankan aplikasi Flutter dengan menjalankan widget MyApp().
- class MyApp extends StatelessWidget { ... }: Ini adalah kelas yang mewakili aplikasi utama. Ini adalah turunan dari StatelessWidget yang berarti tidak memiliki state yang berubah selama eksekusi aplikasi.
- build(BuildContext context) { ... }: Metode build adalah metode yang didefinisikan oleh StatelessWidget yang menggambarkan antarmuka pengguna aplikasi. Metode ini mengembalikan tampilan antarmuka pengguna yang diinginkan. Di sini, kita mengembalikan widget MaterialApp yang berisi judul, tema, dan tampilan form MyForm().
- class MyForm extends StatefulWidget { ... }: Ini adalah kelas yang mewakili form yang berubah-ubah di aplikasi. Ini adalah turunan dari StatefulWidget yang berarti memiliki state yang berubah selama eksekusi aplikasi.
- class _MyFormState extends State<MyForm> { ... }: Ini adalah kelas yang mewakili state dari form. Ini adalah turunan dari State yang menghubungkan antarmuka pengguna dengan state yang terkait.
- final GlobalKey<FormState> _formKey = GlobalKey<FormState>();: Ini adalah kunci global yang digunakan untuk mengakses dan memvalidasi status form. Ini digunakan dalam widget Form untuk menghubungkan form dengan kunci.
- String? name;: Variabel untuk menyimpan nilai input nama dari TextFormField.
- String? gender;: Variabel untuk menyimpan nilai input jenis kelamin dari DropdownButtonFormField.
- String? religion;: Variabel untuk menyimpan nilai input agama dari DropdownButtonFormField.
- String? education;: Variabel untuk menyimpan nilai input pendidikan terakhir dari DropdownButtonFormField.
- List<String> genderOptions = ['Male', 'Female'];: Variabel untuk menyimpan opsi jenis kelamin yang akan ditampilkan dalam DropdownButtonFormField.
- List<String> religionOptions = ['Islam', 'Christianity', 'Catholicism', 'Hinduism', 'Buddhism'];: Variabel untuk menyimpan opsi agama yang akan ditampilkan dalam DropdownButtonFormField.
- List<String> educationOptions = ['Elementary School', 'Junior High School', 'Senior High School', 'Bachelor', 'Master', 'Doctorate'];: Variabel untuk menyimpan opsi pendidikan terakhir yang akan ditampilkan dalam DropdownButtonFormField.
- String result = '';: Variabel untuk menyimpan hasil dari form yang akan ditampilkan sebagai teks.
- void _submitForm() { ... }: Metode yang dipanggil ketika tombol submit ditekan. Metode ini memvalidasi form dan menyimpan nilai input ke dalam variabel name, gender, religion, dan education. Hasilnya akan ditampilkan dalam variabel result.
- build(BuildContext context) { ... }: Metode build dari MyForm yang menggambarkan antarmuka pengguna dari form. Di sini, kita menggunakan Scaffold sebagai kerangka utama dan menempatkan elemen-elemen form di dalamnya.
- TextFormField: Widget untuk input teks yang digunakan untuk memasukkan nama. Properti validator digunakan untuk memvalidasi input, sedangkan onSaved digunakan untuk menyimpan nilai input ke dalam variabel name.
- SizedBox: Widget yang digunakan untuk memberikan ruang kosong (jarak) antara elemen-elemen dalam tampilan.
- DropdownButtonFormField: Widget untuk dropdown select input yang digunakan untuk memilih jenis kelamin, agama, dan pendidikan terakhir. Properti value digunakan untuk menyimpan nilai saat ini, items digunakan untuk menentukan pilihan yang tersedia, dan onChanged digunakan untuk memperbarui nilai saat dipilih.
- ElevatedButton: Widget untuk tombol submit. Properti onPressed digunakan untuk menentukan fungsi yang akan dijalankan ketika tombol ditekan.
- Text: Widget untuk menampilkan teks hasil dari form.
Ok sekarang jalankan emulator. Jika berhasil maka tampilannya akan terlihat seperti gambar di bawah ini.
Mudah bukan?, sekarang kalian dapat membuat dropdown select input dan mengimplementasikannya di project yang sebenarnya. Lakukan improvisasi dengan menggunakan data yang bersumber dari internet agar pilihan jawabannya lebih beragam.
Sekian tutorial kali ini tentang cara membuat dropdown select input di flutter. Semoga tulisan singkat ini membantu. Jika ada pertanyaan silahkan tanya langsung di kolom komentar di bawah ini. Sekian dan terima gaji.
No comments
Jangan lupa kasih komentar ya!. Karena komentar kalian membantu kami menyediakan informasi yang lebih baik
Tidak boleh menyertakan link atau promosi produk saat berkomentar. Komentar tidak akan ditampilkan. Hubungi 081271449921(WA) untuk dapat menyertakan link dan promosi