首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flutter基础(二)

所以初始化函数实际上是 void main(){ return runApp(new MyApp()); } class MyApp extends StatelessWidget { @...Flutter框架将依次构建这些widget,直到构建到最底层的子widget时,这些最低层的widget通常为RenderObject,它会计算并描述widget的几何形状。...,Scaffold显示的才是整个页面 2、MaterialApp/WidgetApp class MaterialApp extends StatefulWidget MaterialApp的主要作用是定义一些整体的风格...MaterialApp 提供了大量的美观、功能丰富的控件,放弃MaterialApp等于放弃了一整片森林。...,如果说MaterialApp是定义整个App主体、主题之类的角色,Scaffold就是针对当前页面的一个架构了,其中的提供了一些组件属性 appBar:顶部标题栏 body:用来展示 APP 的主体部分

99130
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Flutter 中 stateless 和 stateful widget 的区别

    小部件的状态 状态是在构建期间同步读取小部件类的信息 - 也就是说,当小部件显示在屏幕上并且如果信息在其生命周期内发生更改时可能会发生变化。...出于这个原因,外观和属性在小部件的整个生命周期中保持不变。 当我们描述的 UI 部分不依赖于任何其他小部件时,无状态小部件会很有用。无状态小部件的示例是文本、图标、图标按钮和凸起按钮。...例如,当我们创建一个AppBar](,无状态小部件可以是不需要更改的脚手架或图标。 无状态小部件类仅在初始化时调用一次。即使有外力作用在它上面,它也不会更新。...之后,小部件将打印在屏幕上。 但是如果我们希望它在有动作时更新,我们必须制作一个有状态的小部件。 有状态的小部件 当 UI 的某些部分必须在运行时动态更改时,使用有状态小部件。...有状态的小部件可以在应用程序运行时多次重绘自己。 当我们描述的 UI 部分动态变化时,有状态小部件很有用。如果我们创建一个按钮小部件,每次用户单击该按钮时都会更新自身,这就是一个有状态小部件。

    2.3K10

    Flutter 系列之GetX的学习(1) --> 状态管理

    路线管理: GetX 提供了用于在 Flutter 应用程序内导航的 API。此 API 非常简单,所需代码较少。...但是你有没有停下来想一想,你的appBar,你的脚手架,以及你的类中的大部分widget都是无状态的?那么如果你只能保存有状态的Widget的状态,为什么要保存整个类的状态呢?Get也解决了这个问题。...更新widgets而不需要为此花费ram。Get只存储GetBuilder的创建者ID,必要时更新该GetBuilder。get ID存储在内存中的消耗非常低,即使是成千上万的GetBuilders。...当你创建一个新的GetBuilder时,你实际上是在共享拥有创建者ID的GetBuilder的状态。不会为每个GetBuilder创建一个新的状态,这为大型应用节省了大量的内存。...基本上你的应用程序将是完全无状态的,而少数有状态的Widgets(在GetBuilder内)将有一个单一的状态,因此更新一个状态将更新所有的状态。状态只是一个。

    9410

    flutter 起步

    flutter简介Flutter是谷歌的移动UI框架,可以运行在ios与android系统上,可以以完成app的开发,使用情况页面大多数涉及到flutter 开发的app 都是混合开发,占比并不多。...当为true时,在debug模式下显示右上角的debug字样的横幅,false即为不显示Scaffold 有下面几个主要属性:appBar - 显示在界面顶部的一个 AppBar。...将程序中的类结构更新完成后,Flutter会立即重建整个控件树,从而更新界面。...全局变量和静态成员变量,这些变量不会在热刷新时更新。修改了main函数中创建的根控件节点,Flutter在热刷新后只会根据原来的根节点重新创建控件树,不会修改根节点。...热刷新无法实现更新时,执行一次热重启(Hot Restart)就可以全量更新所有代码,同样不需要重启App,区别是restart会将所有Dart代码打包同步到设备上,并且所有状态都会重置。

    4.5K20

    原来Flutter代码是这样运行在原生系统的!快来了解Flutter标准模板,感受原生系统中Flutter的魅力!

    ,包含: AppBar,页面导航栏,直接将MyHomePage中的title属性作为标题使用 body,Text组件,显示了一个根据_counter属性可变的文本:‘You have pushed the...图计数器示例的代码流程示意图,把这实例的整个代码流程串起: MyApp为Flutter应用的运行实例,在main函数中调用runApp函数实现程序的入口。...对StatefulWidget,当数据改变时,需重建Widget去更新界面,即Widget创建销毁会很频繁。...6 总结 先通过Flutter标准模板创建了计数器示例,并分析了Flutter的项目结构,以及Flutter工程与原生Android、iOS工程的联系,知道了Flutter代码是怎么运行在原生系统上的。...然后,学习示例项目代码,了解了Flutter应用结构及页面结构,并认识了构建Flutter的基础,也就是Widget,以及状态管理机制,知道了Flutter页面是如何构建的,StatelessWidget

    48120

    Flutter学习笔记:BottomNavigationBar实现多个Navigation

    最近我研究了一下Flutter,但是在使用Navigator的时候遇到了一个很头痛的问题,就是当我们去来回切换导航按钮时,Flutter会重新build,从而导致控件重新Build,从而会失去浏览历史。...当新页面出现时,整个``BottomNavigationBar```及其内容会滑动。 不酷。? ?...在标签之间切换似乎不起作用,因为我们总是在Scaffold主体内显示红色页面。 多个Navigator 这是因为我们已经定义了一个新的导航器,但这是在所有三个选项卡中共享的。...One more thing 如果我们在Android上运行应用程序,当我们按下后退按钮时,我们会发现一个有趣的现象: ?...1_qQW2iGXiWL2F1tu6cLQfwg.gif 需要注意的一点是,当我们在Android上推送新路线时,会从底部滑入。 相反,惯例是在iOS上从右侧滑入。

    4.3K20

    Flutter容器类组件

    由于矩阵变化只会作用在绘制阶段,所以在某些场景下,在UI需要变化时,可以直接通过矩阵变化来达到视觉上的UI改变,而不需要去重新触发build流程,这样会节省layout的开销,所以性能会比较好。...color和decoration是互斥的,实际上,当指定color时,Container内会自动创建一个decoration。...Flutter Material 组件库提供了一些现成的组件来减少我们的开发任务。Scaffold,中文称之为脚手架,为开发者提供了路由页面的整体架构,开发者可以借助它快速便携地实现一个完整的页面。...如果开发者提供了抽屉菜单,那么当用户手指从屏幕左(或右)侧向里滑动时便可打开抽屉菜单。...body 最后就是页面的 Body 部分了,Scaffold 有一个 body 属性,接收一个 Widget,我们可以传任意的 Widget ,在后面介绍滑动组件时,会涉及到 TabBarView,它是一个可以进行页面切换的组件

    3.9K40

    Flutter 1.22 正式发布

    即使在这么短的时间内,我们也关闭了3,024期,合并了197个贡献者的1,944个PR。在这些贡献者中,有114位(58%)来自整个社区,他们贡献了271个PR。...您可以在cupertino_icons预览页面上看到图标的完整列表,在 flutter.dev上可以看到迁移详细信息页面。...但是,在此版本中,我们将最佳做法的意见纳入了我们的工具中,甚至在添加新的l10n信息时启用了热重装支持来更新您的应用。 ?...您可以在OnPopPage回调中更新状态,例如,如果用户弹出,则表示他们已“取消选择”当前颜色,因此我们不再希望显示该页面。...= true; run(MyApp()); } 根据所涉及的频率差异,启用此标志可以使滚动时的颤动减少多达97%。

    7.5K20

    小荷才露尖尖角,和Flutter应用说你好

    内部的数据有变化都可以理解为受控,并不需要像React去setState或者调用useStata去更新 对于Vue3 内部数据使用ref和reactive包裹的是受控组件 在Flutter...的样式都是以widget的形式提供的 感觉样式写起来没有纯css快啊 但是仔细一想,这样代码读起来对新手比较友好了 对新手来说,Flutter的样式控制应该更加容易理解 Flutter在构建页面时...React的类组件汇总改变状态的方式很像 听说Flutter对这个方法做了优化,不需要去修改每个widget,源码还没有了解过 构建UI界面的build方法 当MyHomePage第一次创建时,...incrementCounter, tooltip: 'Increment', child: Icon(Icons.add), ), ); } Scaffold是Material库中提供的页面脚手架...,它提供了默认的导航栏,标题和包含主屏幕widget树的body属性。

    8710

    Flutter跨平台移动端开发

    虽然从效果来看,父 widget 的限制没有起作用,但是实际上它只是没有影响子 widget 的大小,但还是占有了响应的空间 ---- DecoratedBox(装饰盒) decoratedBox 可以给子...background = 在子 widget 之后绘制,foreground = 在子 widget 之前绘制 child:子 widget /** * @des DecoratedBox Widget...: constraints, super(key: key); width、height:当一级标签与 constraints 中同时包含 width、height 时,...---- Scaffold Widget and TabBar Widget(脚手架及切换组件) scaffold 是 Materrial 库中提供的一个脚手架,可以帮助开发者更快的完成功能页的开发...---- 本篇到此完结,更多 Flutter 跨平台移动端开发 原创内容持续更新中~ 期待您 关注 / 点赞 / 收藏 向着 大前端工程师 晋级! ----

    2.8K40

    实现Flutter应用中的全局导航栏效果

    然后,我们在HomePage中使用Consumer来订阅导航栏状态,并根据状态来构建页面内容。当导航栏状态发生变化时,页面会自动更新。...当点击按钮时,会更新count的值,并在所有依赖于MyInheritedWidget的地方进行通知和更新。...案例研究:全局导航栏应用 背景: 假设我们正在开发一个移动应用,该应用包含多个页面,并希望在整个应用中使用全局导航栏来管理页面之间的导航。...需求: 我们希望实现以下功能: 在整个应用中使用相同的导航栏样式和布局。 点击导航栏项时,能够在不同页面之间切换,并且导航栏的选中项能够同步更新。 导航栏的状态能够在应用的不同页面之间共享。...在应用的各个页面中使用Consumer来获取导航栏的状态,并根据状态来显示不同的页面内容。通过这种方式,我们实现了全局导航栏效果,并确保了导航栏在不同页面之间的同步更新。

    17911

    flutter鸿蒙版本通过底部导航栏的实现熟悉架构及语法

    写在前面 在这篇博客中,我们将深入分析一个 Flutter 应用的完整代码,该应用实现了一个底部导航栏,允许用户在不同页面之间切换。...runApp() 方法会将传入的 Widget 加载到屏幕上。 3....当用户点击某个导航项时,这个方法会被调用,并通过 setState 方法更新 _selectedIndex,触发界面重建,从而显示新选中的页面。 6....顶部应用栏 appBar 属性设置了应用的顶部导航栏,显示了应用的标题。 显示页面 body 属性通过 _pages[_selectedIndex] 动态显示当前选中的页面。...onTap 属性将点击事件绑定到 _onItemTapped 方法,使得点击导航项时可以更新状态和切换页面。 7.

    10310

    Flutter完整开发实战详解(十二、全面深入理解状态管理设计)

    如下方代码所示,利用 scoped_model 实现状态管理只需要三步 : 定义 Model 的实现,如 CountModel ,并且在状态改变时执行 notifyListeners() 方法。...scoped_model 的整个实现流程中,ScopedModel 这个 Widget 很巧妙的借助了 AnimatedBuildler 。...之后我们可以 dispatch 一个 Action ,在经过 middleware 之后,触发对应的 Reducer 返回数据,而事实上这里核心的内容实现,还是 Stream 和 StreamBuilder...比如你一个点击行为只是发出一个 RefrshAction ,但是通过 middleware 拦截之后,在其中异步处理完几个数据接口,然后重新 dispatch 出 Action1、Action2 、Action3 去更新其他页面...fish_redux 从控件到页面更新,全都进行了新的独立设计,而这里面最有意思的,莫不过 dependencies 。

    2.1K20

    Flutter BLoC 异步通信、BlocBuilder的基本使用、BlocProvider的初探

    BLoC模式可以将Widget构建UI的代码与业务处理的代码分离出来,在BLoC模式下的应用程序,一般会有全局的BLoC,每一个页面也会对应有一个独立的BLoC。...中使用BloC时,首先要引入bloc库 dependencies: flutter_bloc: ^6.0.6 然后将依赖库拉取到本地 flutter packages get 在Flutter BloC...(); ///取消计时器 _timer.cancel(); } @override Widget build(BuildContext context) { ///页面主体脚手架...return Scaffold( appBar: AppBar( title: Text("Bloc "), ), body:buildBlocBuilder..., ) 然后在子页面中 通过 BlocBuilder 分别引用不同的 Bloc 就可以,小编这也有 Demo 点击查看详情 *** 完毕 以小编的性格,要实现百万Demo随时复制粘贴肯定是需要源码的 BlocProvider

    3.4K11

    Flutter 中键盘弹起时,Scaffold 发生了什么变化

    image Scaffold 的 resize Scaffold 是 Flutter 中最常用的页面脚手架,前面知道了通过 resizeToAvoidBottomInset ,我们可以配置在键盘弹起时页面的底部按键和...(注意,在 widget.appbar 不为 null 时,会 removeTopPadding) 所以如下图代码所示 body 在添加时,它父级的MediaQueryData 会被重载,特别是 removeTopPadding...如下图所示,键盘弹起因为被 resize 了,所以界面的 bottom 安全区域变成了 0 ,而 在 MainWidget 中可以获取到 viewInsets.bottom 也就是键盘的高度; 在 CustomWidget...事实上这得从 MaterialApp 说起,在 MaterialApp 内部的深处嵌套着一个叫 _MediaQueryFromWindow 的 Widget ,它在内部通过 WidgetsBinding.instance.addObserver...Dart 层,从而触发 MaterialApp 内的 didChangeMetrics 方法执行 setState(() {}); ,进而让 _MediaQueryFromWindow 内的 build 更新了

    2.1K20
    领券