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

开始使用-编写你第一个Flutter应用程序 顶

第1步:创建起始Flutter应用程序 第2步:使用外部包装 第3步:添加一个有状态小部件 第4步:创建一个无限滚动ListView 第5步:添加交互性 第6步:导航屏幕 第7步:使用主题更改UI...查找和使用包来扩展功能。 使用热重载加快开发周期。 如何实现有状态小部件。 如何创建一个无限,延迟加载列表。 如何创建并导航第二个屏幕。 如何使用主题更改应用程序外观。...有关如何设置环境信息,请参阅Flutter安装和设置。 第1步:创建起始Flutter应用程序 使用第一个Flutter应用程序入门说明创建一个简单模板化Flutter应用程序。...lib/main.dart 第6步:导航屏幕 在这一步,您将添加一个显示收藏夹新屏幕(在Flutter称为路由)。 您将学习如何在主路由和新路由之间导航。...新页面的内容是使用匿名函数在MaterialPageRoutebuilder属性构建。 将呼叫添加到Navigator.push,如突出显示代码所示,将路由推送到导航堆栈。

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

Flutter新页面:通过下拉刷新提升用户体验

下拉更新基础 下拉刷新是应用移动端一个常见模式,它允许用户手动刷新页面内容。在 Flutter ,这个功能被封装在 RefreshIndicator 挂件。...使用 BuildContext 来管理状态和导航 BuildContext 是 Flutter 基本概念,它表示一个挂件在 widget tree 位置。...它可以从父挂件获取数据,管理状态并在页面之间导航。当实现下拉刷新,我们经常需要 BuildContext 来触发状态更改或者在刷新后导航不同屏幕。...处理数据并刷新操作 在 Flutter 应用引入一个 pull-to-refresh 特性不仅仅是视觉交互,也是关于如何高效处理数据和更新手势操作。..._handleRefresh 函数可以使用热加载来更改和测试,而不影响其他 widget tree。

15210

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

最近我研究了一下Flutter,但是在使用Navigator时候遇到了一个很头痛问题,就是当我们去来回切换导航按钮时,Flutter会重新build,从而导致控件重新Build,从而会失去浏览历史。...首先,看一下免责声明: 本文假设您熟悉Flutter导航。 更多知识,请参阅Navigation基础知识教程,以及Navigator,MaterialPageRoute和MaterialApp。...这是我们确保使用多个导航器所需。 我们脚手架身体现在是一个有三个孩子堆栈。 每个子项都在_buildOffstageNavigator()方法构建。...回顾 今天我们学习了很多关于Flutter导航知识,以及如何结合BottomNavigationBar,Stack,Offstage和Navigator控件来实现多个导航堆栈。...使用Offstage小部件可确保我们所有导航器保留其状态,因为它们保留在控件树。 这可能会带来一些性能损失,因此如果您选择使用它,我建议您分析您应用。 可以在此处找到本文完整源代码

4.2K20

flutter路由

路由管理控制 路由是一个应用程序抽象屏幕或页面; 路由管理就是管理页面之间如何跳转; 路由入栈指打开一个新页面; 路由出栈指一个页面关闭操作; 路由管理指如何来管理路由栈; Navigator是一个管理路由...maybePop 导航器是否可以弹出,可以的话弹出 pop 弹出路由 popUntil 一直弹出直到指定路由 removeRoute 删除指定路由 removeRouteBelow 立即从导航删除一条路由...,然后[Route.dispose]要替换路线是给定“ anchorRoute”下方路线。...MaterialApp,这个上下文不包含Navigator导航器操作, 所以我们应该把home那部分抽出来放另一个类; 路由传值并返回值 路由传参在上面那个例子已经有了,num就是我们参数,然后显示在标题上就是使用了...= null) print('接收到参数:$value'); }); } 这样我们就能push新页面然后点击返回按钮就能把参数返回到push那个方法,然后在then打印出来了: I/flutter

1.7K20

Flutter 可折叠边栏

一个可在Flutter应用创建可折叠侧边栏导航抽屉 Flutter 插件。...Flutter使开发人员可以轻松使用导航抽屉,而无需其他人就无需编写大部分代码。 在本博客,我们将探讨Flutter **可折叠侧边栏。...**我们将实现一个可折叠侧边栏演示程序,并在flutter应用程序中使用foldable_sidebar包创建一个可折叠侧边栏导航抽屉。...它是一个向左滑动菜单,在大多数情况下,它包含应用程序重要连接,并且在显示时拥有一半屏幕。 该演示视频展示了如何Flutter创建可折叠侧边栏。...它显示了在flutter应用程序中使用foldable_sidebar包可折叠侧边栏将如何工作。它显示了当用户点击浮动操作按钮时,抽屉将以折叠方式显示/隐藏。它会显示在您设备上。

6.3K50

Flutter 构建完整应用手册-设计基础知识 顶

这本食谱包含演示如何在写Flutter应用程序时解决常见问题食谱。 每个配方都是独立,可以作为参考帮助您构建应用程序。...路线 导入字体文件 在pubspec.yaml声明该字体 将字体设置为默认值 在特定部件中使用字体 1.导入字体文件 为了处理字体,我们需要将字体文件导入项目中。...路线 将字体添加到包 将包和字体添加到我们应用程序 使用字体 1.将字体添加到包 要从包中导出字体,我们需要将字体文件导入到我们包项目的lib文件夹。...添加一个抽屉屏幕上 在采用Material Design应用导航有两个主要选项:选项卡和抽屉。 当没有足够空间来支持标签时,抽屉提供了一个方便选择。...使用Navigator! 当用户打开抽屉时,Flutter会将抽屉添加到引擎盖下导航堆栈。 因此,要关闭抽屉,我们可以调用Navigator.pop(context)。

7.1K10

Flutter Drawer 侧边栏以及侧边栏布局

在iOS原生开发,实现抽屉视图还是比较麻烦,有时还需要借助第三方组件来实现。但是在Flutter,我们利用Drawer组件就可以很轻松实现抽屉视图。...2,配置了Scaffolddrawer属性或者endDrawer属性之后,flutter会自动帮我们在顶部导航左侧或者右侧加上一个按钮,如下图所示: ?...DrawerHeader可以自定义,想实现啥功能就实现啥功能;而 UserAccountsDrawerHeader 布局、样式和内容是固定,如果对个性化要求不高,个人还是倾向于使用UserAccountsDrawerHeader...8,可以通过配置 ListTile onTap 来监听 ListTile 点击事件。...那么,当点击抽屉视图中某个组件来跳转到另外一个页面,然后从这个页面返回时候,如何让抽屉视图消失呢?

5.4K20

Flutter如何使用WillPopScope示例代码

Flutter如何实现点击2次Back按钮退出App,如何实现App多个Route(路由),如何实现Back按钮只退出指定页面,此篇文章将告诉你。...App中有多个Navigator,想要是让其中一个 Navigator 退出,而不是直接让在 Widget tree 底层 Navigator 退出。...在使用TabView、BottomNavigationBar、CupertinoTabView这些组件时,希望有多个Tab,但每个Tab中有自己导航行为,这时需要给每一个Tab加一个Navigator...使用TabView、BottomNavigationBar、CupertinoTabView这些组件时也是一样原理,只需在每一个Tab中加入Navigator,不要忘记指定key。...总结 到此这篇关于Flutter如何使用WillPopScope文章就介绍这了,更多相关flutter使用WillPopScope内容请搜索ZaLou.Cn以前文章或继续浏览下面的相关文章希望大家以后多多支持

2.7K40

Flutter 构建完整应用手册-处理手势

处理点击 我们不仅希望向用户展示信息,还希望我们用户与我们应用进行互动! 那么,我们如何回应基本操作,如点击和拖动? 我们将使用GestureDetector部件!...路线 创建一个我们想要点击部件 将其包装在InkWell部件以管理点击回调和涟漪动画 // The InkWell Wraps our custom flat button Widget new InkWell...路线 创建条目列表 将每个项目包裹在Dismissible部件 提供“向后消除”指标 1.创建条目列表 这个配方第一步是创建一个我们可以滑动项目列表。...有关如何创建列表更多详细说明,请按照使用长列表配方进行操作。 创建一个数据源 在我们例子,我们需要20个样品条目。 为了简单起见,我们将生成一个字符串列表。...用户将该项目删除后,我们需要运行一些代码以从列表删除该项目并显示Snackbar。 在真实应用程序,您可能需要执行更复杂逻辑,例如从Web服务或数据库删除项目。

1.8K20
领券