如何对齐 ListTile 中的文本?

How to align the text within ListTile?

有没有其他方法可以让我在不使用 Row 小部件的情况下在 ListTile 的前导和标题内对齐文本?数据是从 Firebase 获取的,然后使用 Listview 查看。生成器。

FutureBuilder(
  future: fetchData(),
  builder: (context, snapshot) {
    if (snapshot.hasData) {
      List<taskData> result = snapshot.data as List<taskData>;

      return ListView.builder(
          scrollDirection: Axis.vertical,
          itemCount: result.length,
          itemBuilder: (BuildContext context, int i) {
            DateTime updateDate = DateTime.fromMillisecondsSinceEpoch(result[i].date);
            String formDate = DateFormat('yMMMd').format(updateDate);

            return GestureDetector(
              onTap: () {
                NavigationController(context, 'Edit', 'Title',
                    result[i].task, result[i].id, updateDate);
              },
              child: Card(
                child: ListTile(
                  leading: Text(formDate, style: TextStyle(fontFamily: 'ProximaNova', fontSize: 16),),
                  title: Text('${result[i].task}',style: TextStyle(fontFamily: 'ProximaNova',fontSize: 18),),
                  trailing: IconButton(
                    icon: Icon(Icons.delete),
                    onPressed: () {
                      id = result[i].id;
                      showDialog<void>(
                          context: context, builder: (context) => dialog);
                    },
                  ),
                ),
              ),
            );
          });
    } else if (snapshot.hasError) {
      print('${snapshot.error}');
      return Text(
        "",
        style: TextStyle(fontSize: 20),
      );
    }

    // By default, show a loading spinner.
    return Center(
        child: Container(
      margin: EdgeInsets.symmetric(vertical: 100.0),
      child: CircularProgressIndicator(),
    ));
  },
),

参考图片('title'与'leading'和'trailing'不对齐):

抱歉,如果我没有解决所问的问题,但作为建议,如何将其包装在行小部件中而不是居中对齐的列表拼贴中?

首先,我认为您的前导与标题和尾随不一致,我不知道您的代码中发生这种情况的原因是什么。解决方案可能是将您的两个文本都放在带有 + 运算符的标题中。或领导任何有助于您解决问题的人。

It is working for you

ListTile(
       leading: Text('2021-04-27'),
       title: Text('Lion', textAlign: TextAlign.center,),
       trailing: IconButton(
                icon: Icon(Icons.delete),
                onPressed: () {},                  
      ),
    ),