This post was updated 896 days ago and some of the ideas may be out of date.
这里记录我学习Flutter的笔记
图像
圆角图像
方法一
child: Container(
width:300,
height: 300,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(30),
//圆角方法一
image: DecorationImage(
image:NetworkImage("https://www.riceshare.com/wp-content/uploads/2022/07/1657510345-GifCam1.gif"),
fit: BoxFit.cover,
),
方法2
child: ClipOval(
child: Image.network("https://www.riceshare.com/wp-content/uploads/2022/07/1657510812-%E5%9B%BE%E7%89%87.jpg.webp",
fit: BoxFit.cover,
),
列表
静态
列表属性
- scrolDirection Axis 列表垂直或水平
- padding EdgeInsetsGeometry 内边距
- resolve bool 组件反向排序
- children List
列表内容
最简单实例
return ListView(
children: [
//用在Listview里面
ListTile(
leading: Icon(Icons.settings,
color: Colors.yellow,
),
//添加图标
title: Text("这是今天的好内容!"),
subtitle: Text("简介1242464565435545675743254576897656345676543546854"),
trailing: Icon(...),
//在后面添加图标
),
ListTile(
title: Text("这是今2天的好内容!"),
subtitle: Text("简介1242464565435545675743254576897656345676543546854"),
),
ListTile(
title: Text("这是今3天的好内容!"),
subtitle: Text("简介1242464565435545675743254576897656345676543546854"),
),
//省略
],
//垂直列表
scrollDirection: Axis.vertical,
padding: EdgeInsets.all(12),
);
动态
实现方法
- 使用For循环实现
使用For循环方式
class Contains extends StatelessWidget{
//自定义一个方法使用For循环返回List
List<Widget> _getData(){
List<Widget> list = [];
for(var i = 0;i<20;i++){
list.add(ListTile(
title: Text('这是第$i个列表!!!'),
),);
}
return list.toList();
}
@override
Widget build(BuildContext context) {
// TODO: implement build
//设置一个ListView
return ListView(
children: this._getData(),
);
}
}
Map方法
ListData.dart文件
List listDatas=[
{
"title": 'Candy Shop',
"author":"Moanghs",
"imageUrl":'https://i0.hdslb.com/bfs/archive/08e9af7deb7ef87448095c2eba544c033232d061.jpg@336w_190h_1c.webp',
},
{
"title": 'Shop',
"author":"Dccansssghs",
"imageUrl":'https://i0.hdslb.com/bfs/archive/1c2e265ebc1a60a40f1444de325c83b7c30061cb.jpg@336w_190h_1c.webp',
},
{
"title": 'ssdShop',
"author":"adrghs",
"imageUrl":'https://i0.hdslb.com/bfs/archive/0eedab326cd1230c4f11586399f470825d7954cc.png@336w_190h_1c.webp',
},
{
"title": 'Candy Shop',
"author":"Moanghs",
"imageUrl":'https://i0.hdslb.com/bfs/archive/08e9af7deb7ef87448095c2eba544c033232d061.jpg@336w_190h_1c.webp',
},
{
"title": 'Shop',
"author":"Dccansssghs",
"imageUrl":'https://i0.hdslb.com/bfs/archive/1c2e265ebc1a60a40f1444de325c83b7c30061cb.jpg@336w_190h_1c.webp',
},
.........
];
import 'res/listData.dart';
class Contains extends StatelessWidget{
//Map方法
List<Widget> _getData(){
var tempList=listDatas.map((value){
return ListTile(
leading: Image.network(value["imageUrl"]),
title:Text(value["title"]),
subtitle: Text(value['author']),
);
});
return tempList.toList();
}
@override
Widget build(BuildContext context) {
// TODO: implement build
return ListView(
children: this._getData(),
);
}
}
ListView.builder方法
import 'res/listData.dart';
class Contains extends StatelessWidget{
@override
Widget build(BuildContext context) {
// TODO: implement build
return ListView.builder(
//列表长度
itemCount:listDatas.length,
itemBuilder: (context,index){
return ListTile(
//index是索引值 eg 0.1.2.3.4
title: Text(listDatas[index]['title']),
);
}
);
}
}
将Builder抽离
class Contains extends StatelessWidget{
Widget _getListData(context,index){
return ListTile(
//index是索引值 eg 0.1.2.3.4
title: Text(listDatas[index]['title']),
);
}
@override
Widget build(BuildContext context) {
// TODO: implement build
return ListView.builder(
//列表长度
itemCount:listDatas.length,
//把._getListData赋值给 itemBuilder
itemBuilder: this._getListData
);
}
}
自定义按钮组件
class Home extends StatelessWidget {
@override
Widget build(BuildContext context) {
// TODO: implement build
return Iconcont(Icons.add,color: Colors.black,);
}
}
class Iconcont extends StatelessWidget{
double size=32.0;
Color color=Colors.white;
var icon;
Iconcont(this.icon,{this.color=Colors.white,this.size=32}){
}
@override
Widget build(BuildContext context) {
// TODO: implement build
return Container(
height: 100,
width: 100,
color: Colors.red.shade500,
child: Center(
child: Icon(this.icon,color: this.color,size: this.size,),
),
);
}
}
Row布局 横向布局
- mainAxisAlignment 主轴(x)显示(Center...)
- crossAxisAlignment y轴
Column 垂直布局
与row大同小异 略...
主轴与Row互换
Expanded 布局 (flex布局)
类似于线性布局 平均分配内部的内容
class Home extends StatelessWidget {
@override
Widget build(BuildContext context) {
// TODO: implement build
return Row(
children: [
Expanded(
child: Iconcont(Icons.add,color: Colors.red,),
flex: 1,
),
Expanded(child: Iconcont(Icons.home,color: Colors.pink,),flex: 2,),
],
);
}
}
class Iconcont extends StatelessWidget{
double size=32.0;
Color color=Colors.white;
var icon;
Iconcont(this.icon,{this.color=Colors.white,this.size=32}){
}
@override
Widget build(BuildContext context) {
// TODO: implement build
return Container(
height: 100,
width: 100,
color: this.color,
child: Center(
child: Icon(this.icon,color: Colors.white,size: this.size,),
),
);
}
}
实现宽度100%
width = MediaQuery.of(context).size.width
参与讨论