data:image/s3,"s3://crabby-images/071b3/071b358e14eeee371423845748fc5e761e73758d" alt="StoreApp - Text 간격주기"
1. 하나하나 정렬하기
Spacer(), // 남는 공간 차지하기
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Row( // 가로 행 children: [ Spacer(), Text("Woman"), Spacer(), Text("Kids"), Spacer(), Text("Shoes"), Spacer(), Text("Bag"), Spacer(), ], ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/e08f5/e08f55060754f9aaef9d4c34cdb2f934235664f8" alt="notion image"
data:image/s3,"s3://crabby-images/b6df3/b6df3ee5756db1d73776ca792969fe823eb6f7e8" alt="notion image"
data:image/s3,"s3://crabby-images/dddb9/dddb9d96f8ff61d133aff94ef07422001a36b5ec" alt="notion image"
2. 한번에 정렬하기
- 기본이 가로 행인지 세로 행인지에 따라 같은 키워드지만 값이 달라짐
data:image/s3,"s3://crabby-images/492cc/492ccc5b6e081b65a974d4eff8dd3a37a47a59ff" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceEvenly, children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/8de16/8de160a236eceba49af72780b97eb3f12ab6ac0e" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/c07ce/c07ced31279dd6a52de38e427d9ceeed5d0edf23" alt="notion image"
3. Text 위 아래 간격 주기
- padding은 있으나 margin은 없음!
Padding(); // 간격주기
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.all(8.0), child: Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/eeaae/eeaae3156fd637405f08b529980c25baa35a97f3" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.all(25.0), child: Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/d40ec/d40ec37370b6adde9d1944e941ff12e878ac9074" alt="notion image"
4. Padding 사용하기
padding: const EdgeInsets.symmetric(vertical: 25),
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { // 상태가 없는 위젯 const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( debugShowCheckedModeBanner: false, // 배너 해제 home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.symmetric(vertical: 25), child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, // space랑 동일 children: [ Text( "Woman", style: TextStyle(fontWeight: FontWeight.bold), ), // Text 상태변수 Text( "Kids", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Shoes", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Bag", style: TextStyle(fontWeight: FontWeight.bold), ), ], ), ), Expanded( flex: 1, child: Image.asset( "assets/bag.jpeg", fit: BoxFit.cover, ), ), SizedBox( height: 10, ), Expanded( flex: 1, child: Image.asset( "assets/cloth.jpeg", fit: BoxFit.cover, ), ), ], ), ), ); // 페이지는 Scaffold 구조로 만든다. } }
data:image/s3,"s3://crabby-images/1a87d/1a87d73410eb7641992eee902af38689fbf3575a" alt="notion image"
padding: const EdgeInsets.only( left: 10, right: 20, top: 50, bottom: 5),
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { // 상태가 없는 위젯 const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( debugShowCheckedModeBanner: false, // 배너 해제 home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.only( left: 10, right: 20, top: 50, bottom: 5), child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, // space랑 동일 children: [ Text( "Woman", style: TextStyle(fontWeight: FontWeight.bold), ), // Text 상태변수 Text( "Kids", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Shoes", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Bag", style: TextStyle(fontWeight: FontWeight.bold), ), ], ), ), Expanded( flex: 1, child: Image.asset( "assets/bag.jpeg", fit: BoxFit.cover, ), ), SizedBox( height: 10, ), Expanded( flex: 1, child: Image.asset( "assets/cloth.jpeg", fit: BoxFit.cover, ), ), ], ), ), ); // 페이지는 Scaffold 구조로 만든다. } }
data:image/s3,"s3://crabby-images/7faf1/7faf1f5529055ba6f131d88447bbe9015d3b56e7" alt="notion image"
Share article