前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Flutter]Flutter Dart 静态变量值为null的bug

[Flutter]Flutter Dart 静态变量值为null的bug

作者头像
吴老师
发布2018-09-05 11:04:49
2.8K0
发布2018-09-05 11:04:49
举报

Flutter还在学习中,我是以开发一个小的App来学习的,昨天做到一个需求是用户登录后用一个static的变量来缓存登录用户的信息。变量的赋值什么的都没有问题,可是当我在另一个页面想使用这个static的变量的时候,发现它神奇的变成了null。

这个坑爹的问题让我改了很多代码,然而并没有什么卵用,最后不知道是什么促使我google了一下这个关键字“flutter static object value lost”,还真是dart的坑。

可以看一下这个issuse:https://github.com/dart-lang/sdk/issues/32601

原因

dart导入文件的时候可以用相对路径,也中以用package路径,像下面这样:

代码语言:javascript
复制
import 'static_value.dart' as staticA;
import 'package:flutter_study/static_value/static_value.dart' as staticB;

坑爹的地方就在这里,当你用上面两种方式导入同一个dart文件的时候,其实你得到的是使用同一份源代码的两个不同的library

测试一下

新建一个static_value.dart文件,代码如下:

代码语言:javascript
复制
class StaticValue {
  static int testStaticInt;
}

在另一个页面里面用不同的方式导入这个文件,再修改这个testStaticInt变量的值,查看输出结果:

代码语言:javascript
复制
import 'package:flutter/material.dart';
import 'static_value.dart' as staticA;
import 'package:flutter_study/static_value/static_value.dart' as staticB;

class StaticValuePage extends StatefulWidget {

  @override
  State<StatefulWidget> createState() {
    return new StaticValuePageState();
  }
}

class StaticValuePageState extends State<StaticValuePage> {

  @override
  void initState() {
    super.initState();

    staticA.StaticValue.testStaticInt = 1;
    print('staticA: ${staticA.StaticValue.testStaticInt}    staticB:${staticB.StaticValue.testStaticInt}');

    staticB.StaticValue.testStaticInt = 2;
    print('staticA: ${staticA.StaticValue.testStaticInt}    staticB:${staticB.StaticValue.testStaticInt}');

  }

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
        appBar: new AppBar(
          title: new Text('静态变量'),
        ),
        body: Center(
          child: Text(''),
        ));
  }
}

输出结果如下,真的是惊喜意外到想哭。

代码语言:javascript
复制
flutter: staticA: 1    staticB:null
flutter: staticA: 1    staticB:2

解决

这个文件就以一种方式引入

关于Flutter学习

flutter的学习文章及代码都整理在这个github仓库

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.05.24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 原因
  • 测试一下
  • 解决
  • 关于Flutter学习
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档