【问题标题】:Button OnPressed is not working in Flutter按钮 OnPressed 在 Flutter 中不起作用
【发布时间】:2020-04-02 05:23:28
【问题描述】:

我在单击“凸起”按钮时遇到问题。 OnPressed() 内部的方法没有被调用。理想情况下,在 OnPressed() 方法上,我希望显示弹出窗口或滑块。我创建了示例来显示当前面临的问题。

main.dart 文件调用 Screen2()

import 'package:flutter/material.dart';
//import 'package:flutter_app/main1.dart';
import 'screen2.dart';

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

class Lesson1 extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
  home: Screen2(),
);
}
}

在 Screen2() 中,我只有一个 RaisedButton 和 OnPressed(),它需要调用函数 ButtonPressed()。

import 'package:flutter/material.dart';
class Screen2 extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
  appBar: AppBar(
    backgroundColor: Colors.blue,
    title: Text('Screen 2'),
  ),
  body: Center(
    child: RaisedButton(
      color: Colors.blue,
      child: Text('Go Back To Screen 1'),
      onPressed: () {
        print('centrebutton');
        ButtonPressed();
      },
    ),
  ),
  );
 }
 }
class ButtonPressed extends StatefulWidget {
@override
_ButtonPressedState createState() => _ButtonPressedState();

}

class _ButtonPressedState extends State<ButtonPressed> {
@override
Widget build(BuildContext context) {
print ('inside button press');

return Scaffold(
  appBar: AppBar(
    backgroundColor: Colors.red,
    title: Text('Screen 3'),
  ),
  // create a popup to show some msg. 
 );
 }
 }

点击“升起”按钮后,打印语句('centerbutton')会被打印出来。
但是 ButtonPressed() 方法没有被调用。 我无法在控制台中看到 print msg('inside button press')。 PL。让我看看 ButtonPressed 方法没有被调用的原因。附上截图供您参考。

【问题讨论】:

    标签: flutter dart


    【解决方案1】:

    您正在 RaisedButton 的 onPressed 方法上调用 Widget。您的小部件正在被调用,但不会在屏幕上的任何位置呈现。

    您应该在点击事件中调用一个函数来处理您的数据。但是您正在调用一个小部件或说一个 UI 视图。

    如果你想导航到相应的屏幕,那么你应该使用导航器。

    例如:

    onPressed: () {
            print('centrebutton');
            Navigator.push(context, MaterialPageRoute(builder: (BuildContext context) => ButtonPressed()));
          },
    

    【讨论】:

    • 没错,杰伊
    • 在按钮上单击我需要显示一个弹出或底部滑块。我不打算导航到另一个屏幕
    • 实际上可以,有一个用于警告对话框的小部件和用于颤动底部滑块的模式。查看官方文档。
    【解决方案2】:

    这可能是一个原因:如果您有一个资产作为按钮的子项,并且该资产不存在,则按下的按钮将不起作用。

    解决方案:移除资产。

    例子:

    return RaisedButton(
          splashColor: Colors.grey,
          onPressed: () {
           
          },
          child: Padding(
            padding: const EdgeInsets.fromLTRB(0, 10, 0, 10),
            child: Row(
              mainAxisSize: MainAxisSize.min,
              mainAxisAlignment: MainAxisAlignment.center,
              children: <Widget>[
                    Image(image: AssetImage("assets/google_logo.png"), height: 35.0), //remove this line
                Padding(
                  padding: const EdgeInsets.only(left: 10),
                  child: Text(
                    'Sign in with Google',
                    style: TextStyle(
                      fontSize: 20,
                      color: Colors.grey,
                    ),
                  ),
                )
              ],
            ),
          ),
        );
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-11-06
      • 1970-01-01
      • 2020-05-08
      • 1970-01-01
      • 1970-01-01
      • 2019-04-20
      • 1970-01-01
      • 2019-12-12
      相关资源
      最近更新 更多