Flutter如何使用其他文件的参数调用Widget

utugiqy6  于 2023-04-07  发布在  Flutter
关注(0)|答案(2)|浏览(111)

我创建了一个类,存储名为CardWidget与参数的小部件。我将其存储在不同的文件中多次使用它。CardWidget是一个包含标题,描述,日期和帐户等文本数据的小部件。我需要它来创建像它曾经在不同的论坛主页特殊板。
.Widget文件

import 'package:flutter/material.dart';

class CardWidget extends StatelessWidget {
  const CardWidget({Key? key, pcolor, ptext, paccount, pdate, peoplein}) : super(key: key);

  Widget CardWid({pcolor, ptext, paccount, pdate, peoplein}) {
    return Padding(
        padding: EdgeInsets.symmetric(horizontal: 15, vertical: 5),

        // data was erased for economy
        child: Container());
  }

  @override
  Widget build(BuildContext context) {
    return CardWid();
  }
}

当我从另一个flutter类调用它时,它返回一个issue。
类型“Null”不是类型“String”的子类型
.main文件,在这里我调用小部件并给予参数

class HomePageState extends State<HomePage> {
  int _selectedIndex = 0;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: ListView(
        children: [
          CardWidget(
              pcolor: Colors.orangeAccent,
              ptext: 'I need team for First Person Shooter',
              paccount: 'gamedev21',
              pdate: 'February 12, 2023, 21:00',
              peoplein: 2),
          CardWidget(
              pcolor: Colors.green[700],
              ptext: 'text',
              paccount: 'text',
              pdate: 'February 12, 2023, 18:00',
              peoplein: 4),
        ],
      ),
    );
  }
klsxnrf1

klsxnrf11#

您应该在构造函数中输入参数,并在Widget本身中定义它们,如下所示

你的问题存在是因为你传递给CardWidgets的构造函数的值实际上并没有被保存在任何地方,所以当CardWid方法被调用时,参数(类型为dynamic)为null。

// Copyright (c) 2019, the Dart project authors.  Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: HomePage(),
    );
  }
}

class HomePage extends StatelessWidget {
  const HomePage({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return const Scaffold(body:CardWidget(
      pcolor: Colors.orangeAccent,
      ptext: 'I need team for First Person Shooter',
      paccount: 'gamedev21',
      pdate: 'February 12, 2023, 21:00',
      peoplein: 2,
    ),);
  }
}

class CardWidget extends StatelessWidget {
  const CardWidget({
    Key? key,
    required this.pcolor,
    required this.ptext,
    required this.paccount,
    required this.pdate,
    required this.peoplein,
  }) : super(key: key);

  final Color pcolor;
  final String ptext;
  final String paccount;
  final String pdate;
  final int peoplein;

  Widget cardWidget() {
    return Container(
      padding: const EdgeInsets.symmetric(horizontal: 15, vertical: 5),
      color: pcolor,
      child: Column(
        children: [
          Text("$ptext, $paccount, $pdate, $peoplein"),
        ],
      ),
    );
  }

  @override
  Widget build(BuildContext context) {
    return cardWidget();
  }
}
ffscu2ro

ffscu2ro2#

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: HomePage(),
    );
  }
}

相关问题