前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >番外篇-Flutter初识三问

番外篇-Flutter初识三问

作者头像
吴延宝
发布2018-09-10 15:24:38
6250
发布2018-09-10 15:24:38
举报
文章被收录于专栏:中国Android研究院

番外篇-Flutter初识三问

系列:《Flutter从入门到放弃》-04 番外篇 微信公众号:南京Android部落 阅读本文将花费您5分钟左右的时间

问题

  • StatefulWidget与StatelessWidget使用时机?
  • Flutter如何加载图片(网络或者本地)?
  • Scaffold是什么?

讲讲State

在Android中,您可以通过直接对view进行改变来更新视图。然而,在Flutter中Widget是不可变的,不会直接更新,而必须使用Widget的状态。

这是Stateful和Stateless widget的概念来源。一个Stateless Widget就像它的名字,是一个没有状态信息的widget。 例如:在Android中,如果您只想将一个logo使用ImageView展示出来。logo在运行时不会发生改变,在Flutter中可以通过StatelessWidget实现。

但是,如果您希望通过网络请求数据后来更新您的的界面,则需要使用StatefulWidget,并通知Flutter框架(setState)需要更新该widget。

记住官方的一个规则:如果一个widget发生了变化(用户与它交互),它就是有状态的。但是,如果一个子widget对变化做出反应,而其父widget对变化没有反应,那么包含的父widget仍然可以是无状态的widget

加载图片

支持格式:JPEG、WebP、GIF、PNG、BMP、WBMP 主要是通过:

  • 网络
代码语言:javascript
复制
1new Image.network(
2          imgUrl,
3          scale:1.0)
  • 本地
代码语言:javascript
复制
1// 注意path需要包含图片的后缀的
2new Image.asset(path, width:24.0, height: 24.0);

另外在加载资源图片是需要在pubspec.yaml中声明(以上一节的项目为例):

代码语言:javascript
复制
 1flutter:
 2  uses-material-design: true
 3  assets:
 4    - images/tab_association_grey.png
 5    - images/tab_association_yellow.png
 6    - images/tab_discovery_grey.png
 7    - images/tab_discovery_yellow.png
 8    - images/tab_me_grey.png
 9    - images/tab_me_yellow.png
10    - images/tab_sport_grey.png
11    - images/tab_sport_yellow.png
12    - images/tab_training_yellow.png
13    - images/tab_training_grey.png

就上面这些方式吗?答案是否定的。肯定还有别的方式,本期不做介绍,后面用到的时候再补充。

Scaffold是什么

Scaffold实现了Materia design(材料设计)风格的布局结构。Scaffold widget提供了实现:appBar、floatingActionBar等材料设计风格控件的API。所以当我们想要使用MateriaDesign的一些布局方式就会选择Scaffoldwidget。

预告

下一节我们将继续围绕实际项目,通过Flutter来实现效果。主要围绕SliverAppBar的实现效果来讲解。


本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-08-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 南京Android部落 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 番外篇-Flutter初识三问
    • 问题
      • 讲讲State
        • 加载图片
          • Scaffold是什么
            • 预告
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档