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

Flutter 路由参数传递及接收

Navigator 的 push 和 pop方法 Navigator 导航器的 push 和 pop 方法可以携带参数在页面间传递,其他变形的方法也一样。...代码实现 我们使用一个列表跳转到详情页来演示路由参数获取(列表构建文章请看Flutter 入门与实战(五):来一个图文并茂的列表)。点击列表行时携带列表数据项的 id 跳转到详情页。...从详情页返回时再把该 id 回传。列表项的 Widget 新增了一个 id属性,由构建列表时初始化得到。...在详情页中,Flutter 提供了一个ModalRoute的类从当前上下文获取路由配置参数,代码如下所示: class DynamicDetail extends StatelessWidget {...ModalRoute.of(context).settings就是我们上一篇路由拦截中的onGenerateRoute的 settings 参数,因此假设我们需要增加额外的路由参数(例如全局参数),则可以在

1.3K00

深入探究Flutter中的页面导航器:Navigator详解

这个方法接受一个BuildContext对象作为参数,用于将当前页面对应的路由对象从栈中弹出,返回到上一个页面。...在目标页面中,我们可以通过ModalRoute.of(context).settings.arguments来获取传递过来的参数。...'}, ); // 在目标页面中获取传递过来的参数 Map args = ModalRoute.of(context)!....路由保持状态的概念: 路由保持状态是指在页面切换时,保持页面的状态不变,避免页面重新构建和初始化。这种技术可以提升用户体验,减少页面重建的开销,特别是对于包含大量数据或复杂交互的页面而言。 2....在多个导航器之间进行导航: 要在多个导航器之间进行导航,我们可以通过GlobalKey来获取对应的NavigatorState,并调用其push和pop等方法来进行页面跳转和返回。

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

    『React Navigation 3x系列教程』之React Navigation 3x开发指南

    在开始学习7种导航器之前,我们需要先了解两个和导航关于概念: Screen navigation prop(屏幕导航属性):通过navigation可以完成屏幕之间的调度操作,例如打开另一个屏幕; Screen...向路由发送一个action; addListener:订阅导航生命周期的更新; isFocused:true 标识屏幕获取了焦点; getParam:获取具有回退的特定参数; dangerouslyGetParent...并且关闭当前screen.backaction creator接受一个可选的参数: 方法原型:back(key) key:String 可选,这个可以和上文中讲到的goBack的key是一个概念;...与navigate的区别在于,如果有已经加载的页面,navigate方法将跳转到已经加载的页面,而不会重新创建一个新的页面。...,就是要想法获取navigation; 那么,如何才能在非导航器中所定义的屏幕中获取到这个navigation呢?

    4.3K30

    从navigator到react-navigation进阶教程

    在开始学习三种导航器之前,我们需要先了解两个和导航关于概念: Screen navigation prop(屏幕导航属性):通过navigation可以完成屏幕之间的调度操作,例如打开另一个屏幕; Screen...react-navigation精讲 使用state的params 可以通过this.props.state.params来获取通过setParams(),或navigation.navigate()传递的参数...react-navigation精讲 Back 返回到前一个screen并且关闭当前screen.backaction creator接受一个可选的参数: key:这个可以和上文中讲到的goBack的key...,就是要想法获取navigation; 那么,如何才能在非导航器中所定义的屏幕中获取到这个navigation呢?...ref属性获取到navigation,当上述代码的AppNavigator节点被渲染时,ref会被回调这是就可以获取到navigation了,需要提醒大家的是,这种用法对除StackNavigator之外的其他两种类型的导航器也是实用的哦

    3.9K30

    『React Navigation 3x系列教程』createDrawerNavigator开发指南

    从createDrawerNavigator API上可以看出createDrawerNavigator支持通过RouteConfigs和 DrawerNavigatorConfig两个参数来创建createDrawerNavigator...RouteConfigs RouteConfigs支持三个参数screen、path以及navigationOptions; screen(必选):指定一个 React 组件作为屏幕的主要显示内容,当这个组件被...path(可选):用来设置支持schema跳转时使用,具体使用会在下文的有关Schema章节中讲到; navigationOptions(可选):用以配置全局的屏幕导航选项如:title、headerRight...这也可以通过在顶级路由器上使用screenProps.drawerLockMode 动态更新。...可以从props中获取; 打开侧边栏:navigation.openDrawer();; 关闭侧边栏:navigation.closeDrawer();; 切换侧边栏:navigation.toggleDrawer

    7.1K10

    flutter系列之:Navigator的高级用法

    named routes 虽然在flutter中navigator将routers以stack的形式进行存储,能做的也只是push和pop操作,但是事实上Router是可以有名字的。...从定义上可以看到arguments的类型是Object对象,也就是说任何对象都可以作为named route的参数。...在flutter中有两种传递参数的方式,你可以使用ModalRoute.of(),也可以使用onGenerateRoute()。...返回值 有时候我们需要从一个Screen返回到之前的Screen,并且不是简单的返回,我们还希望知道前一个screen返回了什么结果,然后可以根据前一个screen返回的不同结果来进行不同的处理。...向Screen传值 有时候我们需要在页面跳转的过程中传递一些参数,那么怎么才能实现Screen之间的参数传递呢?

    91020

    flutter路由

    ; Navigator 方法 作用 pushNamed 按路由名字路由入栈 pushReplacementNamed 按路由名字替换当前路由栈 popAndPushNamed 将当前路线从导航器中弹出,...pushAndRemoveUntil 将具有给定名称的路由推入导航器,然后删除所有 replace 用新路由替换导航器上的路由 replaceRouteBelow 用新路由替换导航器上的路由。...MaterialApp的,这个上下文不包含Navigator导航器操作, 所以我们应该把home的那部分抽出来放另一个类; 路由传值并返回值 路由传参在上面那个例子已经有了,num就是我们的参数,然后显示在标题上就是使用了...= null) print('接收到的参数:$value'); }); } 这样我们就能push到新页面然后点击返回按钮就能把参数返回到push到它的那个方法,然后在then打印出来了: I/flutter...(21935): 接收到的参数:我是返回值 直接点击左上角那个返回值会为空,这样打印出来的就是: I/flutter (21935): 接收到的参数:null 所以我们做了一个判断,不为空才执行打印

    1.7K20

    react-navigation导航器

    Screen navigationOptions(屏幕导航选项):通过navigationOptions可以定制导航器显示屏幕的方式(例如:头部标题,选项卡标签等) 导航器类型 在react-navigation...中有以下类型的导航器: createStackNavigator:类似普通的Navigator,导航上⽅导航栏 createTabNavigator:已弃用,使⽤createBottomTabNavigator...:订阅导航生命周期的更新 isFocused:true标识屏幕获取了焦点 getParam:获取具有回退的特定参数 dangerouslyGetParent:返回父导航器 注意:一个navigation...跳转 接收两个参数,第一个是定义好的路由名,第二个是页面参数。...可以通过指定⻚面的navigation.state.key来获取⻚页⾯面的标识 key必传,不传默认返回上一页 传参 现在我想定义一个参数给下一个也页面,可以这么做: <Button title

    6.3K20

    Flutter开发(15)- 路由导航

    我们通常会用屏(Screen)来称呼一个页面(Page),一个完整的App应该是有多个Page组成的。...replaces the /// entire screen with a platform-adaptive transition. abstractclass Route { } 事实上MaterialPageRoute...并不是Route的直接子类: MaterialPageRoute在不同的平台有不同的表现 对Android平台,打开一个页面会从屏幕底部滑动到屏幕的顶部,关闭页面时从顶部滑动到底部消失 对iOS平台,打开一个页面会从屏幕右侧滑动到屏幕的左侧...参数传递 因为通常命名路由,我们会在定义路由时,直接创建好对象,比如HYDetailPage() 那么,命名路由如果有参数需要传递呢?...在build方法中ModalRoute.of(context)可以获取到传递的参数 Widget build(BuildContext context) { // 1.获取数据 final message

    98820

    『React Navigation 3x系列教程』之createStackNavigator开发指南

    屏幕转场风格 默认情况下,createStackNavigator提供了转场过渡效果,在Android和iOS上过渡效果是不同的,这也是React Native重平台性的一个体现,在Android上从屏幕底部淡入...,在iOS上是从屏幕的右侧划入,当然你也可以通过配置让StackNavigator支持屏幕从底部滑入的效果。...从createStackNavigator API上可以看出createStackNavigator 支持通过RouteConfigs和 StackNavigatorConfig两个参数来创建createStackNavigator...RouteConfigs RouteConfigs支持三个参数screen、path以及navigationOptions; screen(必选):指定一个 React 组件作为屏幕的主要显示内容,当这个组件被...、headerLeft等; StackNavigatorConfig 从react-navigation源码中可以看出StackNavigatorConfig支持配置的参数有10个。

    5K10

    大前端开发中的路由管理之五:Flutter篇

    ModalRoute:阻止与下层路由交互的路由。它覆盖整个导航器。但它们不一定是不透明的。例如一个对话框。主要处理事件的拦截。 PageRoute:替换整个屏幕的模态路由。...由它派生出了我们熟悉的MaterialPageRoute,主要用于Flutter的页面切换。 PopupRoute:在当前路由上覆盖Widget的模态路由。主要用于弹出框,对话框之类。...2、Flutter路由管理实现 2.1 导航器初始化         Navigator是一个有状态的widget,NavigatorState在初始化时主要做了两件事: 根据配置参数创建初始化路由,初始化路由会放入...]; // 路由栈集合void initState() { _history.addAll([_RouteEntry(route, _RouteLifecycle.add)]);// 1.依据初始化构建参数创建初始化路由...3、Flutter路由管理实现总结         从以上流程实现可以看出,Flutter页面栈的实现依赖于: Navigator持有路由栈,提供导航方法,当路由栈发生变化时同步更新页面栈。

    2.3K30

    第132期:flutter的导航和路由

    命名路由的局限 尽管命名路由可以处理深层链接,但是他们的表现总是一致的,没办法做到自定义。当应用平台接收到一个新的深层链接,不论用户此时在哪个位置,Flutter都会将新的路线推送到导航器上。...当我们使用Router或声明性路由包进行导航时,Navigator上的每个路由页面都是支持的。这表示,路由是根据页面上的使用了页面上参数的Navigator构造函数创建的路由。...如果我们使用的是路由包,则页面支持的路由始终是可深度链接的,而无页面的路由则不是。 当从导航器中删除页面支持的路由时,它之后的所有无页面路由也将被删除。...深度链接 Deep linking Flutter支持iOS、Android和web浏览器上的深度链接。打开URL会在应用程序中显示该屏幕。...默认情况下,web应用程序使用模式:/#/path/to/app/screen从url片段读取深度链接路径,但这可以通过配置应用程序的url策略来更改。

    2K30

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

    最近我研究了一下Flutter,但是在使用Navigator的时候遇到了一个很头痛的问题,就是当我们去来回切换导航按钮时,Flutter会重新build,从而导致控件重新Build,从而会失去浏览历史。...在第38行,我们实现了build(方法,该方法返回一个新的Navigator对象。 这需要一个key和一个initialRoute参数。...这是我们确保使用多个导航器所需的。 我们的脚手架的身体现在是一个有三个孩子的堆栈。 每个子项都在_buildOffstageNavigator()方法中构建。...看一下WillPopScope的文档: 注册用户否决尝试的回调以解除封闭的/// [ModalRoute] 在第4行,我们定义一个onWillPop()回调,如果当前导航器可以弹出则返回false,否则返回...1_qQW2iGXiWL2F1tu6cLQfwg.gif 需要注意的一点是,当我们在Android上推送新路线时,会从底部滑入。 相反,惯例是在iOS上从右侧滑入。

    4.3K20

    手把手教你如何自定义 React Native 底部导航栏

    让我们从创建一个自定义 TabBar 组件开始,该组件只渲染一些文本并打印传递过来的 props ,这样我们就可以看到我们从导航器中得到了什么 props。..., 我们可以添加以下配置作为createBottomTabNavigator 的第二个参数。...现在重新编写 TabBar 组件。首先,让我们尝试重新创建默认选项卡栏。我们将在容器上设置一些样式,以便将选项卡按钮排成一行,并为每个路由呈现一个选项卡按钮。...例如,当前的实现假设选项卡导航器中总会有 4 个 Screen,聚光灯颜色在选项卡栏组件中是写死。...样式应该通过路由器上的 tabBarOptions 配置进行动态编写的,这边不会讲这些,大家自己动手做做。

    7.7K20

    Flutter 小技巧之 MediaQuery 和 build 优化你不知道的秘密

    首先我们需要简单解释一下,通过 MediaQuery.of 获取到的 MediaQueryData 里有几个很类似的参数:viewInsets : 被系统用户界面完全遮挡的部分大小,简单来说就是键盘高度...这就和路由对象的基类 ModalRoute 有关系,因为在它的内部会通过一个 _modalScopeCache 参数把 Widget 缓存起来,正如注释所说:缓存区域不随帧变化,以便得到最小化的构建。...ModalRoute 的类似行为:弹出键盘导致了 MediaQuery 触发 Navigator 执行 rebuild,但是 rebuild 到了 ModalRoute 就不往下影响。...为什么时不时通过 MediaQuery.of(context) 获取的 padding ,有的 top 为 0 ,有的不为 0 ,原因就在于你获取的 context 来自哪里。...,比如前面介绍过的 body ,同时获取到的 MediaQueryData 也会因为 Scaffold 的配置不同而发生改变所以,如下动图所示,其实部分人会在 push 对应路由地方,通过嵌套

    1.2K20
    领券