Лучший способ создать таблицу во Flutter

Здесь я создаю таблицу с использованием контейнера и на основе расширенного с помощью гибкого номера, чтобы сделать заголовок и строку взаимосвязанными. Я думаю, что это не лучший способ, но я не знаю другого способа, как создать такую ​​​​таблицу, кто-нибудь может дать мне предложение?

Вот код:

_tableSection

      Widget _bookingListSection(OnlineBookingListController controller) {
    return Column(
      children: [
        _buildHeaderTable(),
        Expanded(
          child: ListView.builder(
            padding: EdgeInsets.zero,
            itemCount: controller.listBooking.length,
            itemBuilder: (context, index) {
              int lastIndex = controller.listBooking.length - 1;

              return _buildContentTable(
                index,
                lastIndex,
                context,
                controller,
              );
            },
          ),
        ),
      ],
    );
  }

_buildHeaderTable(),

      Widget _buildHeaderTable() {
    return Container(
      width: double.maxFinite,
      height: AppSize.DIMEN_64.h,
      padding: EdgeInsets.fromLTRB(
        AppSize.DIMEN_22.h,
        AppSize.DIMEN_16.h,
        AppSize.DIMEN_22.h,
        AppSize.DIMEN_16.h,
      ),
      decoration: BoxDecoration(
        color: AppColors.GREY_BLACK_BACKGROUND,
        borderRadius: BorderRadius.only(
          topLeft: Radius.circular(AppSize.RADIUS_8.h),
          topRight: Radius.circular(AppSize.RADIUS_8.h),
        ),
      ),
      child: Row(children: [
        _titleHeaderTable('Time', 3),
        _titleHeaderTable('Phone Number', 3),
        _titleHeaderTable('Customer Name', 3),
        _titleHeaderTable('Room', 3),
        _titleHeaderTable('Waitress', 3),
        _titleHeaderTable('Status', 2),
        _titleHeaderTable('Action', 4),
      ]),
    );
  }

Widget _titleHeaderTable(String title, int flexNum) {
    return Expanded(
      flex: flexNum,
      child: Container(
        child: Text(
          title,
          textAlign: TextAlign.left,
          maxLines: 2,
          style: textStyleW700S14.copyWith(
            color: AppColors.WHITE,
          ),
        ),
      ),
    );
  }

Затем для содержимого я использую flex внутри строки. Были ли у вас какие-либо предложения по этому поводу?

2 ответа

Для этого у Flutter есть класс Table (но вы также можете сделать это, используя простую комбинацию Row + Column).

Вот ссылка на документы Table: Flutter Table

      Container(
        color: Colors.white,
        padding: EdgeInsets.all(20.0),
        child: Table(
          border: TableBorder.all(color: Colors.black),
          children: [
            TableRow(children: [
              Text('Cell 1'),
              Text('Cell 2'),
              Text('Cell 3'),
            ]),
            TableRow(children: [
              Text('Cell 4'),
              Text('Cell 5'),
              Text('Cell 6'),
            ])
          ],
        ),
      )

Вы можете создать таблицу во Flutter, используяа также Data Table

  1. Использование класса таблицы:

Обратитесь к классу здесь

      Container(
  margin: EdgeInsets.all(20),
  child: Table(
    defaultColumnWidth: FixedColumnWidth(120.0),
    border: TableBorder.all(
        color: Colors.black, style: BorderStyle.solid, width: 2),
    children: [
      TableRow(children: [
        Column(
          children: [
            Text(
              'Website',
              style: TextStyle(fontSize: 20.0),
            ),
          ],
        ),
        Column(
          children: [
            Text(
              'Tutorial',
              style: TextStyle(fontSize: 20.0),
            ),
          ],
        ),
        Column(
          children: [
            Text(
              'Review',
              style: TextStyle(fontSize: 20.0),
            ),
          ],
        ),
      ]),
      TableRow(children: [
        Column(
          children: [
            Text('https://flutter.dev/'),
          ],
        ),
        Column(
          children: [
            Text('Flutter'),
          ],
        ),
        Column(
          children: [
            Text('5*'),
          ],
        ),
      ]),
      TableRow(children: [
        Column(
          children: [
            Text('https://dart.dev/'),
          ],
        ),
        Column(
          children: [
            Text('Dart'),
          ],
        ),
        Column(
          children: [
            Text('5*'),
          ],
        ),
      ]),
      TableRow(children: [
        Column(
          children: [
            Text('https://pub.dev/'),
          ],
        ),
        Column(
          children: [
            Text('Flutter Packages'),
          ],
        ),
        Column(
          children: [
            Text('5*'),
          ],
        ),
      ]),
    ],
  ),
),

Экран результатов с использованием Class->

  1. Использование класса:

Обратитесь к классу здесь

      DataTable(
  columns: const <DataColumn>[
    DataColumn(
      label: Text(
        'Sr.No',
        style: TextStyle(
          fontWeight: FontWeight.bold,
        ),
      ),
    ),
    DataColumn(
      label: Text(
        'Website',
        style: TextStyle(
          fontWeight: FontWeight.bold,
        ),
      ),
    ),
    DataColumn(
      label: Text(
        'Tutorial',
        style: TextStyle(
          fontWeight: FontWeight.bold,
        ),
      ),
    ),
    DataColumn(
      label: Text(
        'Review',
        style: TextStyle(
          fontWeight: FontWeight.bold,
        ),
      ),
    ),
  ],
  rows: const <DataRow>[
    DataRow(
      cells: <DataCell>[
        DataCell(
          Text('1'),
        ),
        DataCell(
          Text('https://flutter.dev/'),
        ),
        DataCell(
          Text('Flutter'),
        ),
        DataCell(
          Text('5*'),
        ),
      ],
    ),
    DataRow(
      cells: <DataCell>[
        DataCell(
          Text('2'),
        ),
        DataCell(
          Text('https://dart.dev/'),
        ),
        DataCell(
          Text('Dart'),
        ),
        DataCell(
          Text('5*'),
        ),
      ],
    ),
    DataRow(
      cells: <DataCell>[
        DataCell(
          Text('3'),
        ),
        DataCell(
          Text('https://pub.dev/'),
        ),
        DataCell(
          Text('Flutter Packages'),
        ),
        DataCell(
          Text('5*'),
        ),
      ],
    ),
  ],
),

Экран результатов с использованием DataTableКласс->

Вы также можете обратиться к этому пакету за Table

Другие вопросы по тегам