Flutter学习笔记与整合
1.Dart
面向对象语言,与java类比学习
非常适合移动和Web应用程序
1.dart官网
2.Dark2 中文文档
3.Dart语法学习
4.极客学院Dart学习
5.Flutter与Dart 入门
2.Flutter
树形布局,一切皆组件
1.flutter文档
2.社区中文资源
2.flutter中文文档(更新滞后)
3.flutter学习入门:
http://jspang.com/archives/
https://juejin.im/user/59ed44cf6fb9a0451c398c45/posts
4.flutter提升:
https://segmentfault.com/u/yuwanhenshu/articles?sort=created
flutter学习与爬坑:https://www.jianshu.com/nb/26101414
https://github.com/CarGuo/GSYGithubAppFlutter
3.爬坑
1.listview嵌套listview
子listview需要制定高度,使用 shrinkWrap: true 内容适配高度;
滑动类型设置: physics: new NeverScrollableScrollPhysics(), 禁止子模块列表滑动影响下拉刷新
https://blog.csdn.net/hao_m582/article/details/84112278#ListView_1
2.SimpleDialog
需要指定宽和高
3.验证码倒计时重发实现
使用dart的async包下的 Timer.periodic 实现
https://www.jianshu.com/p/f7a9b8c84d26
4.微信分享插件
先注册APPID
https://pub.dartlang.org/packages/sy_flutter_wechat
5.将图像保存到照片库
https://pub.dartlang.org/packages/image_picker_saver
6.屏幕溢出问题
水平溢出:
对于图片,动态的text数据,需要对container容器的宽度做计算约束,适配不同大小的手机
constraints: BoxConstraints(maxWidth: _descWidth),
获取屏幕宽度
MediaQuery.of(context).size.width
垂直溢出:
对于不是滑动页面会出现底部溢出,使用 SingleChildScrollView 包裹,使其滑动,避免垂直溢出
7.Dialogs, alerts
flutter中弹窗是相当于一个页面,一个新的context
8.页面传参
方式一:Navigator
flutter子父页面传参,相对前端而言很简单,因为dart是面相对象的语言,可以在导航中通过有参构造传参
使用Navigator
组件,然后使用路由MaterialPageRoute
传递参数
父》子, 子》父
final result = await Navigator.push(
context,
MaterialPageRoute(
builder: (context) => new OtherPage(param: param),
));
Navigator.pop(context,'$result'); //xxx就是返回的参数
方式二:事件监听传值
使用eventBus, import 'package:event_bus/event_bus.dart';
1创建事件
class OnTapEvent {
Map data;
OnTapEvent (this.data);
}
2发出事件 eventBus.fire(new OnTapEvent());
3监听事件
eventBus.on<OnTapReportEvent>()
.listen((OnTapEvent data) {
//TODO
});
9.移动平台中启动URL
打开默认浏览器,或跳转其他页面
https://pub.dartlang.org/packages/url_launcher#-readme-tab-
10.顶部,底部TabBar控件
https://juejin.im/post/5b685a2a5188251ac22b71c0
11.LocalStorage
持久化到手机
https://pub.dartlang.org/packages/shared_preferences
12.dio是一个强大的Dart Http请求库,支持Restful API、FormData、拦截器、请求取消、Cookie管理、文件上传/下载、超时等...
https://github.com/flutterchina/dio/blob/flutter/README-ZH.md
13.升级flutter SDK
https://flutter.io/docs/development/tools/sdk/upgrading
Flutter学习笔记与整合的更多相关文章
- SpringMVC:学习笔记(10)——整合Ckeditor且实现图片上传
SpringMVC:学习笔记(10)——整合Ckeditor且实现图片上传 配置CKEDITOR 精简文件 解压之后可以看到ckeditor/lang下面有很多语言的js,如果不需要那么多种语言的,可 ...
- Flutter学习笔记(3)--Dart变量与基本数据类型
一.变量 在Dart里面,变量的声明使用var.Object或Dynamic关键字,如下所示: var name = ‘张三’: 在Dart语言里一切皆为对象,所以如果没有将变量初始化,那么它的默认值 ...
- Flutter学习笔记(4)--Dart函数
如需转载,请注明出处:Flutter学习笔记(4)--Dart函数 Dart是一个面向对象的语言,所以函数也是对象,函数属于Function对象,函数可以像参数一样传递给其他函数,这样便于做回调处理: ...
- Flutter学习笔记(5)--Dart运算符
如需转载,请注明出处:Flutter学习笔记(5)--Dart运算符 先给出一个Dart运算符表,接下来在逐个解释和使用.如下: 描述 ...
- Flutter学习笔记(6)--Dart异常处理
如需转载,请注明出处:Flutter学习笔记(6)--Dart异常处理 异常是表示发生了意外的错误,如果没有捕获异常,引发异常的隔离程序将被挂起,并且程序将被终止: Dart代码可以抛出并捕获异常,但 ...
- Flutter学习笔记(8)--Dart面向对象
如需转载,请注明出处:Flutter学习笔记(7)--Dart异常处理 Dart作为高级语言,支持面向对象的很多特性,并且支持基于mixin的继承方式,基于mixin的继承方式是指:一个类可以继承自多 ...
- Flutter学习笔记(9)--组件Widget
如需转载,请注明出处:Flutter学习笔记(9)--组件Widget 在Flutter中,所有的显示都是Widget,Widget是一切的基础,我们可以通过修改数据,再用setState设置数据(调 ...
- Flutter学习笔记(10)--容器组件、图片组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...
- Flutter学习笔记(11)--文本组件、图标及按钮组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 文本组件 文本组件(text)负责显示文本和定义显示样式,下表为text常见属性 Text组件属性及描述 属性名 类型 默认 ...
随机推荐
- 洛谷P4843 清理雪道
题意:给你DAG,求最小路径边覆盖.路径可重. 解:首先可以想到边转点,发现有n²条边,果断超时. 有源汇有上下界最小流. 建图:每条边都建立一条边,流量限制为[1, 1]. 源点向每个点连边,因为都 ...
- Spring的后置处理器BeanFactoryPostProcessor
新建一个JavaBean UserBeanFactoryPostProcessor 实现了BeanFactoryPostProcessor接口 Spring配置文件如下: 编写测试用例 从结果可以看出 ...
- A1056. Mice and Rice
Mice and Rice is the name of a programming contest in which each programmer must write a piece of co ...
- [luogu2822][组合数问题]
题目链接 题解: 对于上面和下面的式子进行分解质因数,然后看看上面的质因数个数减去下面的质因数个数能不能达到k的质因数的要求即可. 分解质因数的时候用对于阶乘分解质因数的常用方法:比如要求1999!中 ...
- javascript:location.reload()和location.replace()的区别,及对图片缓存的影响。
有段时间没有清理IE的临时文件(缓存文件),在我清理的时候,我突然发现一个问题. 我打开的一个网站,图片默认缓存一个月的,但我发现,当我上传图片或删除图片之后,图片重新缓存,也就意味着,在我上传新图片 ...
- python之配置日志的几种方式
作为开发者,我们可以通过以下3种方式来配置logging: 1)使用Python代码显式的创建loggers, handlers和formatters并分别调用它们的配置函数: 2)创建一个日志配置文 ...
- Java + 腾讯邮箱 SSL加密问题 重要通知
原来的jdk8版本如果不替换jce就会在发邮件的过程中报错,而此次使用的jdk1.8.0_131,并没有出现问题,也就是说,如果你使用的版本是 就不用考虑发邮件因为加密算法而导致的错误了
- Cookie浅谈
相信大家对Cookie多多少少都有点了解吧~~下面我来谈谈吧: 每个Cookie不超过4K数据,每个网站不超过20个Cookie,所有网站的Cookie总和不超过300个 虽然cookie已经是上世纪 ...
- 面向对象【day07】:类的实例化过程剖析(三)
本节内容 1.概述 2.类的语法 3.总结 一.概述 之前我们说关于python中的类,都一脸懵逼,都想说,类这么牛逼到底是什么,什么才是类?下面我们就来讲讲,什么是类?它具有哪些特性. 二.类的语法 ...
- DotNetBar滚动条的疑似BUG
1.重现过程,在winform窗体上拖一个VScrollBarAdv 2.Button里点击跟踪代码 3.Value居然是-5,,而不是0,这是直接赋值,不是手动拖的呀. 4.解决办法,将LargeC ...