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

使用导航组件: 条件导航 | MAD Skills

这是第二个关于导航 (Navigation) 的 MAD Skills 系列,本文是导航组件系列的第二篇文章,如果您想回顾过去发布的内容,请参考下面链接查看: 导航组件概览 导航到对话框 在应用中导航使用...概述 条件导航 (Conditional navigation) 指的是在为应用设计导航,您可能需要基于条件逻辑将用户转到某一个目的地而非另一个。...在 上一篇文章 中,我使用 NavigationUI 实现了应用的底部导航,并增加了 SelectionFragment 来启用或禁用咖啡记录功能。...我将使用 Datastore API 来保存用户的选择,并据此决定是否在底部导航中展示 coffeeList 目的地。...在应用中使用条件导航的准备工作 这是自上一篇文章以来我所做 修改 的快速回顾: 首先,我添加了 UserPreferencesRepository,它使用 DataStore API 来保存用户的选择;

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

【Jetpack】Navigation 导航组件 ⑤ ( NavigationUI 类使用 )

的重要工具 , 可以极大地提高开发效率 ; 一、NavigationUI 类简介 NavigationUI 是 Google 官方提供的 用于管理 Navigation 导航组件 , 属于 Android...可以 通过 NavigationUI 轻松地管理页面的转换和导航 ; NavigationUI 提供了一些静态方法来处理 顶部应用栏 / 抽屉式导航栏 / 底部导航栏中 的界面导航 ; 本篇博客中介绍一种使用场景...: 使用 AppBar 中的菜单选项控制 Navigation 界面跳转 ; 在 Activity 中 , 使用 Navigation 组件 切换 Fragment 界面 , 除了进行界面切换之外..., 会自动生成对应的 布局文件 : 注意 : 该操作比较坑 , 生成 Fragment , 会自动添加 Kotlin 语言插件的 Gradle 依赖 , 必要可以删除该依赖 ; 自动生成的依赖没有配置..., navController) 代码的含义是 : 优先使用 NavigationUI 进行导航 , 如果跳转失败 , 再使用传统的方式执行默认动作 , 代码为 super.onOptionsItemSelected

73540

Git提交使用.gitignore文件忽略特殊文件

在工作中或者日常开发中,我们使用 Git 进行开发上传至 Github 等托管平台,有些时候,我们必须把某些文件放到 Git 的工作目录中,但是又不能提交它们,比如保存了数据库密码的配置文件、ide 的配置文件等等...,Git 就会自动忽略这些文件 忽略文件的原则是: 忽略操作系统自动生成的文件,比如缩略图等 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库...,比如ThinkPHP5框架产生的runtime文件 忽略你自己的带有敏感信息的配置文件,比如ThinkPHP5框架根目录下的.env配置数据库文件 举个栗子 使用 ThinkPHP5 框架进行开发,使用...如果你确实想添加该文件,可以用-f强制添加到 Git $ git add -f .idea 所以在使用 Git 的时候想要忽略某些文件,需要编写.gitignore 沈唁志|一个PHPer的成长之路...原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:Git提交使用.gitignore文件忽略特殊文件

2.6K30

新手使用 Vue 忽略而导致的 Bug

一个萌新在初次独立使用 Vue 这个框架,难免会出现很多意外的,我也是在这条路上跌跌撞撞,遇到了很多看似很奇怪的 Bug,却怎么也不知道哪里错了。...路由和导航 在 Vue 中,路由一般是由 Vue-router 实现的,在主页面中(View)存在一个 router-view 的标签,当地址发生改变,仅仅会在 router-view 中的部分会被重载...根据 Vue 生命周期, $refs 内的元素在 mounted 后才能使用。 在 created() 中如需调用,可以使用 setTimeOut() 的特征来实现。...$refs.dom)) 3} COPY Array 内部元素监听问题 在父子组件传参,如果父组件使用数组内的元素传参,之后数组内的元素在父组件被直接赋值修改,Vue将无法监听到变化。...导致父组件里的元素看似改变了,但是子组件的值仍然没有改变。 请使用 this.$set(targetArray, index, value) 对 Array 赋值. 其他 还请大佬指正。

48330

在应用中导航使用 SafeArgs | MAD Skills

今天为大家发布本系列文章中的第三篇: 在应用中导航使用 SafeArgs。...如果您看到这篇文章的时候较晚,那么应该会有一个更新的版本供您使用。只要和您所使用导航组件 API 的其它模块的版本一致就可以了。...另外需要注意的是,应用现在使用该对话框添加新的元素 (我在上一篇文章 使用导航组件: 对话框目的地 | MAD Skills 中已经介绍),同时也使用该对话框编辑已有元素。...请继续关注我们后续的关于导航组件的内容,接下来我们会介绍如何使用 Deep Link。...更多信息 更多关于导航组件的详情,请查看 导航组件使用入门文档 DonutTracker 应用的完整代码,请查看 Github 示例 更多现代 Android 开发技巧 (MAD Skills) 系列内容

1.5K20

React Native导航Navigator组件基本使用方法

最近在学React Native,了解了一个原本iOS中非常重要的导航控件的使用方法。...不过在React Nativa中,这个导航控件是不会自带顶部的导航栏的,也不会自动生成返回按钮之类的,只是提供了类似的导航功能,且原理也是出栈入栈的方式,也就是说同样是有着push和pop方法的。...这里不讲React Native的基础了,直接讲一讲Navigator这个组件的基本使用方法。...对于一个导航组件,最基本的就是下面几个点: 进入下一个界面 返回上一个界面 传递数据给下一个界面 返回数据给上一个界面 我们一个一个来看。...首先要使用Navigator组件,按照惯例是要import它的,这个别忘了。

1.5K20

【Jetpack】Navigation 导航组件 ① ( Navigation 引入 | Navigation 特点 | Navigation 重要组件 | Navigation 使用流程 )

Bar 管理过程中使用比较繁琐 , 维护难度较大 ; Jetpack 提供的 Navigation 组件 , 解决上述 Fragment 页面管理 与 App Bar 管理 问题 ; Navigation...: 该组件是 NavHostFragment 中的管理对象 , 用于管理应用中的导航操作 , 主要是完成在 Navigation Graph 中定义的页面切换操作 ; 通过 NavController...可以轻松地跳转到不同的目的地 , 并处理回退操作 ; 切换 Fragment 显示流程 : 使用 NavController 组件 切换 Fragment , 设置 要跳转的 定义在 Navigation...Graph 中定义的 Fragment ; NavController 组件 会将 指定的 Fragment 显示到 NavHostFragment 组件中 ; 四、Navigation 使用流程 -...组件 执行 Fragment 页面跳转 , 并添加动画效果 使用 NavController 组件实现页面导航 使用 Safe Args 插件安全传递数据 创建 Navigation Graph 组件有一个前提

46440

ElementUI使用Upload组件传递额外参数

前言 这学期写过一个项目,用到了Element中的Upload组件,项目的需求是除了上传文件到后端,还需要传递额外的参数,在这里耗了一点间,在网上找了很多解决办法,但都不是我需要的,这里记录一下。...的官网说明能不能再详细一点) 说明: 前端:Vue 后端:Flask 这里我需要传递的参数是存储在Session中的username 正文 前端 根据官网的说明,如果要用Upload传递除文件之外的其他参数,需要使用到...'username': sessionStorage.getItem('username'), } } }, .... } Upload组件使用如下..." type="success" @click="submitUpload()">上传至服务器 后端 flask接收data传递的参数,...直接使用request.form[]语法接收对象中定义的变量,而非接收对象本身 # 文件上传 @file_bp.route('/fileupload', methods=['GET','POST'])

3.7K20

使用导航组件: 对话框目的地 | MAD Skills

概览 在本系列的 上一篇文章 中,我大致介绍了导航组件以及如何使用导航图。 在这篇文章中,我会介绍如何使用 API 来导航到对话框目的地 (dialog destination)。...id 将导航目的地改变为对话框,这里的 id 正是在导航图中创建目的地所生成的。...其次,我们从 FAB 导航 (不需要传递参数给 Directions 对象) 调用 navigate() 方法和从甜甜圈列表中任一列表项导航 (需要传递 donut.id) 不太一样。...注意: 点击返回按钮,同样会返回甜甜圈列表,因为导航组件已经自动为我们设置好了返回栈。 总结 通过这篇文章我们了解了如何使用内置的导航组件快速地创建一个新应用,并且学习了如何导航到对话框目的地。...更多信息 更多关于导航组件的详情,请查看 导航组件使用入门文档 DonutTracker 应用的完整代码,请查看 Github 示例 更多 MAD Skills 系列内容,请查看 Android Developers

1.4K30

Android使用开源组件PagerBottomTabStrip实现底部菜单和顶部导航功能

PagerBottomTabStrip 是一个基本按谷歌Material Design规范完成的安卓底部导航栏控件 官方设计规范:https://www.google.com/design/spec/components.../bottom-navigation.html 1、前言 (1)底部选择菜单功能应该是大多app都会用到的,实现方式也有很多种,比较笨的方法可以自定义一个xml,下方布局样式,每次点击不同按钮跳转到不同...2、底部导航菜单功能代码 1、首先需要引用包: compile 'me.majiajie:pager-bottom-tab-strip:2.2.5' 2、然后写一个主的activity和底部点击进入的两个...--上方导航条返回按钮-- <LinearLayout android:id="@+id/back_btn" android:layout_width="0dp" android...(2)在上里面的代码中我们使用了矢量图<Vector 功能,实现标准是美工提供.svg文件,通过studio直接转为xml文件的图片,优势是可伸缩和完美放大,体积小,需要知道一下。

1.5K31

实践 | 为 Trackr app 适配大屏幕设备

△ 左侧: 手机上的导航展示。右侧: 平板上的导航展示。 调整后: 当屏幕变宽,我们显示导航轨道 (navigation rail) 来取代底部应用栏。...调整后 : 在大尺寸屏幕上,我们使用DialogFragment,于是编辑任务的界面就悬浮在了其他内容之上。...△ 悬浮的编辑组件将关注点放在用户当前的目标内容上 起初我们尝试将编辑任务界面取代任务详细信息 (Task Detail) 显示在详细信息窗格中。...原本全屏显示编辑界面,这种请求很容易被拦截,因为唯一离开此界面的方式就是使用返回键。...使用 DialogFragment 之后,所有的这些元素都位于对话框之后,使得用户不能与它们交互,这恰恰是我们想要的效果。

1.7K20

Python中使用deepdiff对比json对象,对比如何忽略数组中多个不同对象的相同字段

最近忙成狗了,很少挤出时间来学习,大部分时间都在加班测需求,今天在测一个需求的时候,需要对比数据同步后的数据是否正确,因此需要用到json对比差异,这里使用deepdiff。...一般是用deepdiff进行对比的时候,常见的对比是对比单个的json对象,这个时候如果某个字段的结果有差异,可以使用exclude_paths选项去指定要忽略的字段内容,可以看下面的案例进行学习:...那么如果数据量比较大的话,单条对比查询数据效率比较低,因此,肯呢个会调用接口进行批量查询,然后将数据转成[{},{},{}]的列表形式去进行对比,那么这个时候再使用exclude_paths就无法直接简单的排除某个字段了...除非自己一个个去指定要排除哪个索引下的字段,不过这样当列表的数据比较多的时候,这样写起来就很不方便,代码可读性也很差,之前找到过一个用法,后来好久没用,有点忘了,今晚又去翻以前写过的代码记录,终于又给我找到了,针对这种情况,可以使用

63420

VUE 使用新版本 element-ui 组件库 Select 组件, value 值为对象的 BUG 处理

VUE 使用新版本 element-ui 组件库 Select 组件, value 值为对象的 BUG 处理 在公司项目中,我们使用了 element-ui 组件库,非常的好用。...近日我们的项目升级,而 element-ui 组件库也升级了。而升级的内容中有我们希望使用的新特性,于是我们愉快的升级了。 但是在升级之后,我们发现在某一块功能中使用的 Select 组件出现了问题。...我们退回到 element-ui@1.3.7 版本,问题消失。因此,我们初步判断,这是 element-ui 的 BUG。 为了解决这个问题,我们自己写了一个下拉组件。...但是我总感觉 element-ui 应该不会有这么明显的问题。今天仔细看了一下官方更新文档,焕然大悟。 ? 迅速查看文档 ?...问题找到之后,我们没在项目中使用自己写的组件,而是还原成使用 element-ui 的组件了。 PS: 这篇文章的次要重点是提醒那些遇到同样问题的朋友。

1.5K100

Vue3使用插槽的父子组件传值

Vue3使用插槽的父子组件传值 用法见官方文档深入组件章节,插槽部分: 参考文档:插槽-作用域插槽-插槽prop 作用域插槽 有时让插槽内容能够访问子组件中才有的数据是很有用的。...需求:插槽内容能够访问子组件中才有的数据 实现 子组件 TodoList.vue <div v-for="(todoItem, index) in state.todoList...,如上代码中的 item 和 index ; 子<em>组件</em>将子<em>组件</em>中定义的数据通过插槽属性传递给父<em>组件</em>; 父<em>组件</em> useSlot.vue ...当<em>使用</em>具名插槽<em>时</em> ......属性slotProps获取子<em>组件</em>传递过来的插槽属性 注意: 属性只能在插槽内部才能获取 具名插槽写法 演示 [%E6%8F%92%E6%A7%BD%E7%88%B6%E5%AD%90%E7%BB%84%

1.9K20

【Jetpack】Navigation 导航组件 ④ ( Fragment 跳转中使用 safe args 安全传递参数 )

: https://github.com/han1202012/Navigation 一、页面跳转间的传统的数据传递方式 1、传统的数据传递方式 - Bundle 传递数据 1、Navigation 组件中的...Bundle 传递数据安全性差 使用 传统的方式 , 在 Fragment 之间 传递 数据 , 类型很不安全 , 设置 传递的数据 , 需要设置 放入的 数据类型 , 如下代码所示 : // 正常方式传递参数...会出现错误 ; 下面的代码中 , 调用 getInt(“Name”) 也不会报错 ; 上面的 使用 Bundle 在 Fragment 之间传递 参数 , 没有类型检查 , 即使写错了数据类型 也不会报错..., 由于本次使用了 androidx.navigation.safeargs 插件 , 该依赖使用新方式配置无法成功下载 , 这里直接使用老的配置方式 ; dependencyResolutionManagement...savedInstanceState) setContentView(R.layout.activity_main) // fragmentContainerView 组件

44920

解决Android开发中的痛点问题用Kotlin Flow

但选型我们要考虑以下问题,也是LiveData被推荐使用的优势 : 是否会发生内存泄漏,观察者的生命周期遭到销毁后能否自我清理 是否支持线程切换,比如LiveData保证在主线程感知变化并更新UI 不会在观察者非活跃状态下消费事件...然后开启灵魂三问: 在生命周期组件中消费Channel是否会内存泄漏? 不会,因为Channel并不会持有生命周期组件的引用,并不像LiveData传入Observer式的使用。 是否支持线程切换?...使用lifecycle-runtime-ktx库中的launchWhenX方法,对Channel的收集协程会在组件生命周期 < X挂起,从而避免异常。...发现问题 DialogFragment和Activity的通信 我们通常使用DialogFragment来实现弹窗,在其宿主Activity中设置弹窗的点击事件,如果回调函数中引用了Activity对象...消费事件带来的副作用影响用ChannelFlow承载,不会丢失且一对一订阅,只执行一次。使用它可以解决上文提到的痛点一问题。

3.2K20
领券