Flutter 开发常见问题

本文不是讲技术的
本文不是讲技术的
本文不是讲技术的
重要的事情说三遍。。。

之所以发这篇文章,只是为了记录自己在学习 Flutter 的道路上的一些坑,方便以后查找问题。如果有需要的同学也可以从中找到自己的问题解决办法。
本文会持续更新...凡是遇到的问题,都会顺序整理进去。

1.Scaffold.of() called with a context that does not contain a Scaffold.

当你在 dart 文件中要使用 SnackBar 时,需要调用 BuildContext 参数,但是你经常会遇到 在使用的时候报上边的错
为什么会出现这个问题呢?很多时候是因为你传递的 BuildContext 不是 Scaffold 的,而是当前parent widget 的,所以会有这个问题。那么该怎么解决这个问题呢?目前我发现两种方案:
option1:
使用 Builder 包裹

option2:
给Scaffold 设置一个全局 key,通过 key 的如下方法来显示

var _scaffoldkey = new GlobalKey<ScaffoldState>();
Scaffold(
    key: _scaffoldkey,
    body: SafeArea(
        child: _buildContent(),
        ),
)
// 显示 SnackBar 的方法
void showSnackBar(String text) {
    _scaffoldkey.currentState.showSnackBar(SnackBar(
        content: Text(text),
        backgroundColor: Colors.blueAccent,
    ));
}

2.如何获取 Widget 的宽高尺寸呢?

可以使用 context.size.height context.size.width 分别获取 Widget 的宽高尺寸

3.弹出软键盘的时候,在 IOS 平台上遇到无法关闭键盘

有的 IOS 机型上,会遇到这个问题,软键盘调起来了,无法关闭软键盘,那么该怎么处理呢?很简单,其实只需要一行代码就行了: 在你的布局外层,嵌套一层点击,去获取焦点就行了

在布局外层包裹一层点击事件
 InkWell(
        onTap: () {
            FocusScope.of(context).requestFocus(FocusNode());
        },
        child: child
     )

4.Android 嵌套Flutter 后退键返回上一级页面处理

在我们的项目中,参考了 AirBnb 的架构模式,所以只是将 main.dart 文件作为了一个 Flutter 页面的入口,通过 pushName()的方式实现 Flutter 页面的各种调转,包括 Flutter 本身的二级页面跳转,但是在开发这个Flutter-to-Flutter 的页面跳转中,遇到了一个问题:进入第二级页面,然后在 Android 真机上点击系统返回键,竟然直接 彻底退出了,啥叫彻底退出呢?就是二级页面&一级页面都销毁了,,Flutter 所绑定的Activity 也销毁了。。通过源码断点各种跟踪发现,原来是直接调用了 onBackPressd()方法了,所以就有了下边的代码来解决这个问题。。

    override fun onBackPressed() {
        if (flutterView != null) {
            flutterView?.popRoute()
        } else {
            super.onBackPressed()
        }
    }

5.route打开新页面黑屏问题

在 FlutterView 创建的时候,加上如下代码即可:

flutterView.enableTransparentBackground()

6.If you're running an application and need to access the binary messenger before runApp() has been called...

当前Flutter版本 1.10.2
升级到新版本之后,因为之前在 main() 方法中有异步操作,对一些插件做了初始化操作,所以在最新版本中会出现如下报错:

Unhandled Exception: ServicesBinding.defaultBinaryMessenger was accessed before the binding was initialized.
    If you're running an application and need to access the binary messenger before `runApp()` has been called (for example, during plugin initialization), then you need to explicitly call the `WidgetsFlutterBinding.ensureInitialized()` first.
    If you're running a test, you can call the `TestWidgetsFlutterBinding.ensureInitialized()` as the first line in your test's `main()` method to initialize the binding.
    #0      defaultBinaryMessenger.<anonymous closure> (package:flutter/src/services/binary_messenger.dart:73:7)
    #1      defaultBinaryMessenger (package:flutter/src/services/binary_messenger.dart:86:4)
    #2      MethodChannel.binaryMessenger (package:flutter/src/services/platform_channel.dart:140:62)
    #3      MethodChannel.invokeMethod (package:flutter/src/services/platform_channel.dart:314:35)
    <asynchronous suspension>
    #4      FlutterCrashlytics.initialize (package:flutter_crashlytics/flutter_crashlytics.dart:18:53)

解决办法是在 runApp 之前,调用 WidgetsFlutterBinding.ensureInitialized(); 即可解决
注意:如果你不是放在了 main() 方法里边的第一行,而且还发现无效,那么尝试把他放到 main() 里边的第一行再试试,应该会 OK
https://groups.google.com/forum/#!msg/flutter-announce/sHAL2fBtJ1Y/mGjrKH3dEwAJ

https://github.com/flutter/flutter/pull/38464

7.Waiting for another flutter command to release the startup lock...

很多时候你运行 flutter *** 命令的时候,可能会遇到这个提示信息,比如你的 Android Studio 或者 XCode 正在 run, 然后你又去运行 flutter 相关的命令的时候,一定会出现这个,解决办法就是删除一个 lockfile 文件就行了。该文件的目录是:

<YOUR FLUTTER FOLDER>/bin/cache/lockfile

8.RenderBox was not laid out: RenderRepaintBoundary#4bb81 relayoutBoundary=up5 NEEDS-PAINT

原因:在Flutter 的Column或者Row内使用ListView.builder()需要对改ListView的大小进行指定.
解决:具体的解决办法就是 在该ListView.builder()外嵌套一个SizeBox或者Container即可…

更新中......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容