반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 코테준비
- JPA예제
- 알고리즘공부
- JPA 공부
- 스프링 공부
- Flutter
- 자바공부
- querydsl
- 스프링부트공부
- 스프링공부
- 플러터 공부
- nestjs스터디
- 카프카
- JPA
- JPA스터디
- 프로그래머스
- DDD
- 기술면접공부
- 자료구조공부
- 스프링부트
- Axon framework
- 플러터 개발
- 기술공부
- K8S
- 코테공부
- JPA공부
- Kafka
- 스프링
- nestjs공부
- nestjs
Archives
- Today
- Total
DevBoi
[Flutter] Widget 별 가독성 향상 본문
반응형
별건아니고, 저번 포스팅에서 너무 계층이 많다보니, 가독성이 떨어져서
위젯별로 리턴하는 펑션을 분리하고, 해당 펑션으로 대체하여 계층소스에 추가하였다.
이렇게 하니, 좀더 명확하고 직관적이여서 보기 편했다.
추천! 개인적으로 State의 소스가 너무 길어지면... 뎊스에 대해서 헷갈린다.
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
void main() => runApp(LoginApp());
class LoginApp extends StatelessWidget{
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
title: 'Login',
home: Login(),
);
}
}
class Login extends StatefulWidget{
@override
State<Login> createState() => LoginState();
}
class LoginState extends State<Login>{
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Log in'),
elevation: 0.0,
backgroundColor: Colors.red,
centerTitle: true,
leading: IconButton(icon: Icon(Icons.menu),onPressed: (){}),
actions: <Widget>[
IconButton(onPressed: (){}, icon: Icon(Icons.search))
],
),
body: Column(
children: [
const Padding(padding: EdgeInsets.only(top: 50)),
const Center(
child: Text(
textAlign: TextAlign.center,
'logo text'
),
),
Form(child: Theme(
data: ThemeData(
primaryColor: Colors.grey,
inputDecorationTheme: const InputDecorationTheme(
labelStyle: TextStyle(color: Colors.teal,fontSize: 15.0)
)
),
child: Container(
padding: const EdgeInsets.all(40.0),
child: SingleChildScrollView(
child: Column(
children: [
email(),
password(),
const SizedBox(height: 40.0,),
button()
],
),
),
),
))
],
)
);
}
Widget email() => const TextField(
decoration: InputDecoration(labelText: 'Enter email'),
keyboardType: TextInputType.text,
);
Widget password() => const TextField(
decoration: InputDecoration(labelText: 'Enter password'),
keyboardType: TextInputType.text,
obscureText: true,
);
Widget button() => ButtonTheme(
minWidth: 100.0,
height: 50.0,
child: ElevatedButton(
onPressed: (){},
style: ElevatedButton.styleFrom(
backgroundColor: Colors.orangeAccent
),
child: const Icon(
Icons.arrow_forward,
color: Colors.white,
size: 35.0,
),
),
);
}
반응형
'[Mobile] > [Flutter]' 카테고리의 다른 글
[Flutter] assets에 추가하고 IOS 빌드에 추가 (0) | 2023.07.15 |
---|---|
[Flutter] 피그마로 레이아웃 잡고 소스뽑기 (0) | 2023.07.15 |
[Flutter] 간단한 로그인 화면 (0) | 2023.07.11 |
[Flutter] 화면 구성 위젯 이해하기 (0) | 2023.07.11 |
[Flutter] 샘플 프로젝트 분석 (0) | 2023.07.11 |