2

由于文本过长,我遇到了布局问题,我尝试将Expanded/Flexible与导致问题的文本一起使用,以填充它需要的空间,但它已经溢出。我知道这个问题被问了一百次,但我不明白错误在哪里。我尝试分别同时应用于所有行/列(大多数情况下我正在尝试布局以尝试修复它),但我仍然遇到问题......我什至尝试Expanded使用与.FlexibleFittedBoxfit: BoxFit.(all of them)

在此处输入图像描述

Container(
          alignment: Alignment.centerLeft,
          child: Column(
            children: [
              Row(
                crossAxisAlignment: CrossAxisAlignment.start,
                children: [
                  Padding(
                    padding: const EdgeInsets.only(right: 8.0),
                    child: Icon(Icons.directions_car),
                  ),
                  Row(
                    crossAxisAlignment: CrossAxisAlignment.start,
                    children: [
                      Column(
                        crossAxisAlignment: CrossAxisAlignment.start,
                        children: [
                          Text("Text 1"),
                          SizedBox(
                            height: 4,
                          ),
                          Text('TEXT 2'),
                        ],
                      ),
                      SizedBox(
                        width: 27,
                      ),
                      Column(
                        crossAxisAlignment: CrossAxisAlignment.start,
                        children: [
                          Text('1 World Way, Los Angeles, CA 90045, USA',
                            textAlign: TextAlign.left,
                            ),
                          SizedBox(
                            height: 4,
                          ),
                          Text('FLIGHT 3231'),
                        ],
                      ),
                    ],
                  ),
                ],
              ),
            ],
          ),
        );

根据我的理解,如果我错了,请纠正我,应用Expanded/ FlexibleFlexible只占用所需的空间,并Expanded占用所有可用空间,尊重弹性因素。所以大部分时间我都使用灵活的小部件,但这次它不起作用。

在此先感谢您的帮助!

4

4 回答 4

3

尝试使用根据 UI 填充的期望设置值的Expanded小部件。flex

示例代码:

Center(
        child: Container(
      height: 80,
      color: Colors.yellow,
      child: Row(
        mainAxisAlignment: MainAxisAlignment.start,
        children: [
          Padding(
            padding: const EdgeInsets.all(8.0),
            child: Icon(Icons.bus_alert),
          ),
          Expanded(
              flex: 1,
              child: Container(
                width: 1,
                color: Colors.green,
                child: Column(
                  children: [Text("Text 1"), Text("Text 1")],
                ),
              )),
          Expanded(
              flex: 3,
              child: Container(
                color: Colors.blue,
                child: Column(
                  mainAxisAlignment: MainAxisAlignment.spaceAround,
                  children: [
                    Text("1 World Way, Los Angeles, CA 90045, USA"),
                    Text("FLIGHT 3231"),
                  ],
                ),
              ))
        ],
      ),
    ))

注意:使用的文本内容有限制。我们需要确保根据预期的文本长度设置高度。

例子

于 2021-07-20T19:25:19.303 回答
2

您可以使用灵活或扩展的小部件您应该尝试以下代码:

Card(
        shape: RoundedRectangleBorder(
          side: BorderSide(
            color: Colors.blue,
          ),
          borderRadius: BorderRadius.circular(15.0),
        ),
        margin: EdgeInsets.all(16.0),
        child: Container(
          padding: EdgeInsets.all(8.0),
          alignment: Alignment.centerLeft,
          child: Column(
            children: [
              Row(
                crossAxisAlignment: CrossAxisAlignment.start,
                children: [
                  Icon(Icons.directions_car),
                  SizedBox(
                    width: 10,
                  ),
                  Flexible(
                    child: Column(
                      crossAxisAlignment: CrossAxisAlignment.start,
                      children: [
                        Text("Text 1"),
                        SizedBox(
                          height: 4,
                        ),
                        Text('TEXT 2'),
                      ],
                    ),
                  ),
                  SizedBox(
                    width: 27,
                  ),
                  Flexible(
                    child: Container(
                      child: Column(
                        children: [
                          Text(
                            '1 World Way, Los Angeles, CA 90045, USA',
                            textAlign: TextAlign.left,
                          ),
                          SizedBox(
                            height: 4,
                          ),
                          Text(
                            'FLIGHT 3231',
                            textAlign: TextAlign.left,
                          ),
                        ],
                      ),
                    ),
                  ),
                ],
              ),
            ],
          ),
        ),
      ),

你的屏幕是这样的: 像这样的画面

于 2021-07-21T04:17:55.610 回答
1

如果文本真的很长,那么 usingExpanded将根据父窗口小部件对文本进行换行,从而导致字体大小发生变化。您可以考虑使用省略号。

return Container(
  width:300  //give a width of your choice
  child: Text('Any long text',
        overflow:TextOverflow.ellipsis,
         ),
     );
于 2021-07-22T08:00:14.527 回答
1

用固定宽度的容器包装它,然后使用auto_sized_text。或者您可以通过 FittedBox 以固定宽度包装您的 Text 小部件。它会采用同样的方法。随意添加maxLineminFontSize并且maxFontSize' in auto_sized_text. Using Expanded orFlexible 仅在您的文本长度低于给定宽度时影响容器的大小,并且在这种情况下对您没有帮助。

于 2021-07-20T19:08:00.990 回答