Flutter速通指南

2023 XDU-OSC Community - Presented with love by BenderBlog/SuperBart

借助Flutter,他重新实现了校内十分流行的工具软件电表,使得用iOS的同学也有了自己的电表可用。开源和Flutter带来的,对于开发工作的简化以及SuperBart的超级肝力都成为了它能迅速上架iOS并迅速迭代的原因。

原生的电表iOS版本使用了iOS Native开发,在开发效率上略低于先天统一了不同平台实现的Flutter。在运行效率上的提升在业务都相对比较简单的情况下并没有很显著的优势。

其实上面这点也是现在原生客户端开发面对的问题。原生带来了更细致入微的操作粒度,带来更极致的原生性能利用率的同时,对于开发者心智的负担要求很高,也对开发者的能力深入性和熟练度提出了很高的要求;应对这一点的解决方案,有使用Web技术统一全端(就是性能问题和资源利用率一直饱受诟病),也有使用像Flutter这样的混合跨平台框架。后者性能损失相对没那么严重,跨平台能力也相对不错,但是动态程序的本质让它对于低性能设备的友好度较低(比如现在的百度贴吧客户端就是Flutter客户端,面对长列表的加载等场景偶尔会出现崩溃等问题)。

开发效率和程序运行表现基本是一对负相关的参数,其中的取舍就是开发者需要考虑的问题。在程序开发领域,没有银弹。

SuperBart的讲座

Flutter概要

一套代码 (./lib), 多平台运行.

android, windows, linux, ios等.

  • 面向客户端
  • 平台无关
  • 上手简单

Flutter的开发语言是Dart,初见印象:Dart= JS/C++(语言友好度和性能上) + Java(代码风格上) + Dart VM

Basic code format

tldr

  • Empty safety: type? means var is nullable

This will trigger empty check, avoid npe

  • late init

Just like Kotlin

  • Async

Basic layouts

  • Widget
  • Text
  • Warp
  • Row-Column
  • Container

Basic scaffolds

  • AppBar
  • Action
  • TItle
  • TabBar
  • Body
  • BottomBar

Network

主要使用FlutterDio。不过我用http/http.dart更多。

开发笔记

评价是Flutter这玩意搓东西真的快。

Flutter使用的dart语言,强类型和可写性平衡的挺舒服的。语法上,Dart算是JavaScript的继承,语法大差不差,改进了JavaScript混乱的类型系统,还封装了不少挺不错的语法特性,比如那个Future,用着还行。还有内置的高级数据结构之类的,用着挺省心。

不过写这东西,我好像很少单独注意语法层面的东西,一般都是定义个返回Widget的build函数完事。另外这语言比较像DSL,没见过别处有用这玩意的。

关于WebViewWidget

这玩意比较坑的一点是它只支持Android和iOS平台,对于Windows/Linux/Web平台,这玩意都是不支持的。。

所以review同学的代码的时候,发现在我用Linux平台跑的时候报错了。搜了下才发现这问题。

不过也无所谓了,反正这玩意本来就只是在Android/iOS上跑的。

关于TextEditController

声明一个文本框时,它会默认初始化一个TextEditController。如果你传递给它你定义的Controller,它就会使用你提供的而不是自己创建。另外特别注意,给TextField赋值这一项的行为不是常量表达式,不能在它和它的父结构中使用const关键字。

关于sqflite

这玩意有大坑(关于平台兼容性上的)。反正我目前尝试之后发现要么支持Windows/Linux/Mac等桌面端,要么支持Android/iOS等移动端的SQLite使用。

关于ListView

关于这个东西,得注意的就是嵌套使用。嵌套的子ListView,需要设置如下两个属性来避免滚定判定失效:

1
2
shrinkWrap: true,
physics: const NeverScrollableScrollPhysics(),

关于项目结构

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
lib/
|- models/ // Define your data entities here
|- entity1.dart
|- entity2.dart
|- services/ // Implement background service here
|- background_service.dart
|- screens/ // Screens of your app
|- screen1/ // Screen 1 related files
|- screen1.dart
|- screen1_bloc.dart // If you're using BLoC pattern
|- screen2/ // Screen 2 related files
|- screen2.dart
|- screen2_bloc.dart // If you're using BLoC pattern
|- settings/ // Settings related pages
|- settings.dart
|- sub_setting1.dart
|- sub_setting2.dart
|- widgets/ // Reusable widgets
|- providers/ // Provider setup and providers for data and services
|- app_provider.dart // Main provider setup
|- data_provider.dart // Provider for CRUD actions on data entities
|- service_provider.dart // Provider for background service
|- main.dart // Entry point of the app

功能划分基本就这几块:UI,状态管理服务,数据实体,后台服务。代码嘛,能简洁点最好。

另外就我的开发经验而言,最好不要过早规范化工程化。早期过于强调规范和过程的收益是负的。

MISC

  • Invalid kernel binary version

解决方法:清理flutter/bin/cache 下缓存。在Arch Linux下,通过pacman安装的flutter的缓存目录位于/usr/lib/flutter/bin/cache,可以用whereis命令找到。

  • Error fetching devices: XMLHttpRequest error.

在开发flutter web应用遇到的,项目使用了

1
import 'package:http/http.dart' as http;

作为网络请求库。

我遇到的问题是因为跨域造成的,这个提示有很强的误导性:

后端设置一下跨域允许就好了。

作者

xeonds

发布于

2023-09-16

更新于

2025-01-18

许可协议

评论