程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了颤振 int 变为零大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决颤振 int 变为零?

开发过程中遇到颤振 int 变为零的问题如何解决?下面主要结合日常开发的经验,给出你关于颤振 int 变为零的解决方法建议,希望对你解决颤振 int 变为零有所启发或帮助;

我有一个带有一个按钮的屏幕,另一个带有用于显示数字的容器。我在 StatlessWidget 类中声明了一个变量。该按钮将 1 添加到变量中,但是在将 Class 与容器一起离开并返回到它之后,我注意到小部件被更新并且我的变量失去了它的值。我尝试在 initState() 中初始化它,但它仍然失去了它的价值。

import 'package:Flutter/material.dart';
import 'package:generator/route_generator.dart';
import 'package:generator/main.dart';

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

class MyApp extends StatelessWidget {
  @overrIDe
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',theme: themeData(
        priMarySwatch: colors.blue,),initialRoute: '/menu',onGenerateRoute: RouteGenerator.generateRoute,);
  }
}

class Menu extends StatelessWidget {
  int data = 0;
  @overrIDe
  Widget build(BuildContext context) {
    return Scaffold(
        appbar: Appbar(
          title: Text('Menu'),body: Center(
          child: column(
            mainAxisSize: MainAxisSize.min,children: [
              Raisedbutton(
                onpressed: () {
                  Navigator.of(context).pushnamed('/second',arguments: data);
                },child: Text('go to the second'),],));
  }
}

class FirstPage extends StatelessWidget {
  int data = 0;

  voID eins() {
    data = data + 25;
  }

  @overrIDe
  Widget build(BuildContext context) {
    return Scaffold(
        appbar: Appbar(
          title: Text('First Page'),children: [
              Text(
                data.toString(),Raisedbutton(
                onpressed: () {
                  Navigator.pop(context);
                  Navigator.of(context).pushnamed('/second',Raisedbutton(
                child: Text('25'),onpressed: eins,)
            ],));
  }
}

class SecondPage extends StatelessWidget {
  int data = 0;
  SecondPage({Key key,@required this.data}) : super(key: key);

  @overrIDe
  Widget build(BuildContext context) {
    return Scaffold(
        appbar: Appbar(
          title: Text('Second Page'),style: TextStyle(FontSize: 20),Raisedbutton(
                onpressed: () {
                  Navigator.of(context).pushnamed('/first');
                },child: Text('go to the first'),));
  }
}

另一个类

import 'package:Flutter/material.dart';
import 'package:generator/main.dart';
import './main.dart';

class RouteGenerator {
  static Route<dynamic> generateRoute(RouteSetTings setTings) {
    final args = setTings.arguments;

    switch (setTings.@R_450_8313@ {
      case '/first':
        return MaterialPageRoute(
          builder: (_) => FirstPage(),);
      case '/third':
        return MaterialPageRoute(
          builder: (_) => FirstPage(),);
      case '/menu':
        return MaterialPageRoute(
          builder: (_) => Menu(),);

      case '/second':
        // if (args is int) {
        return MaterialPageRoute(
          builder: (_) => SecondPage(
            data: args,);
      //}

      // return _errorRoute();
      //default:
      //return _errorRoute();
    }
  }

  static Route<dynamic> _errorRoute() {
    return MaterialPageRoute(builder: (_) {
      return Scaffold(
        appbar: Appbar(
          title: Text('Error'),body: Center(
          child: Text('ERROR'),);
    });
  }
}

解决方法

关于你的程序的第一件事是你想保留状态,在你的例子中是一个计数器变量,但要做到这一点,你选择了一个无状态小部件。至少你需要一个 StatefulWidget。它已经在名称中了。

也就是说,这并不容易,您可能需要查看 Flutter 中不同的状态管理方法:https://flutter.dev/docs/development/data-and-BACkend/state-mgmt/options

,

为了扩展@nvoigt 所说的内容,请选择一个状态管理解决方案,而不是在页面之间传递参数。通过这种方式,您可以让您的小部件保持无状态,这是首选,但如果没有状态管理解决方案,则无法完成您想做的事情。

这是使用 GetX state management 的快速方法。这可以使用 Provider、RiverPod、Bloc/Cubit 来完成……选择你的毒药。

这是一个包含您的数据和逻辑的新控制器类。

class DataController extends GetxController {
  int data = 0;
  void eins() {
    data += 25;
    update();
  }
}

然后对其余部分进行一些小的更改,您就可以开始使用了。

void main() {
  Get.put(DataController()); // initializing your controller
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',theme: ThemeData(
        priMarySwatch: Colors.blue,),initialRoute: '/menu',onGenerateRoute: RouteGenerator.generateRoute,);
  }
}

class Menu extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text('Menu'),body: Center(
          child: column(
            mainAxisSize: MainAxisSize.min,children: [
              RaisedButton(
                onPressed: () {
                  Navigator.of(context).pushNamed('/second');
                },child: Text('go to the second'),],));
  }
}

class FirstPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final controller = Get.find<DataController>(); // finding controller

    return Scaffold(
        appBar: AppBar(
          title: Text('First Page'),children: [
              GetBuilder<DataController>( // wrap your text in GetBuilder to display variabe
                builder: (_) {
                  return Text(
                    controller.data.toString(),// accessing variable via controller
                  );
                },RaisedButton(
                onPressed: () {
                  Navigator.pop(context);
                  Navigator.of(context).pushNamed('/second');
                },RaisedButton(
                  child: Text('25'),onPressed: () {
                    controller.eins(); // accessing function via controller
                  }),));
  }
}

class SecondPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final controller = Get.find<DataController>(); // finding same instance of controller on new page
    return Scaffold(
        appBar: AppBar(
          title: Text('Second Page'),children: [
              GetBuilder<DataController>(
                builder: (_) {
                  return Text(
                    controller.data.toString(),);
                },RaisedButton(
                onPressed: () {
                  Navigator.of(context).pushNamed('/first');
                },child: Text('go to the first'),));
  }
}

// no longer need to pass anything in your router below

class RouteGenerator {
  static Route<dynamic> generateRoute(RouteSetTings setTings) {

    switch (setTings.@R_450_8313@ {
      case '/first':
        return MaterialPageRoute(
          builder: (_) => FirstPage(),);
      case '/third':
        return MaterialPageRoute(
          builder: (_) => FirstPage(),);
      case '/menu':
        return MaterialPageRoute(
          builder: (_) => Menu(),);

      case '/second':
        // if (args is int) {
        return MaterialPageRoute(
          builder: (_) => SecondPage(),);
      //}

      // return _errorRoute();
      //default:
      //return _errorRoute();
    }
  }

大佬总结

以上是大佬教程为你收集整理的颤振 int 变为零全部内容,希望文章能够帮你解决颤振 int 变为零所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:int颤振