可以根据独立于使用if防护匹配的值的值来匹配模式:
// 让我们想象一个具有以下页面的简单Web应用程序: enum Page { Login, Logout, About, Admin } // 我们已通过身份验证 let is_authenticated = true; // 但是我们不是管理员 let is_admin = false; let accessed_page = Page::Admin; match accessed_page { // 尚未验证的用户可以登录 Page::Login if !is_authenticated => println!("Please provide a username and a password"), // 注销可用于经过身份验证的用户 Page::Logout if is_authenticated => println!("Good bye"), // 关于是公开页面,任何人都可以访问它 Page::About => println!("About us"), // 但是“管理员”页面仅限于管理员 Page::Admin if is_admin => println!("Welcome, dear administrator"), // 对于其他每个请求,我们都会显示一条错误消息 _ => println!("Not available") }
这将显示“不可用”。
可以加上 match 守卫(guard) 来过滤分支。 fn main() { let pair = (2, -2); // 试一试 ^ 将不同的值赋给 `pair` println!("Tell me about {:?}", pair); match pair { (x, y) if x == y => println!("These are t
Guard允许您使用简单优雅的代码写出断言代码。守卫是可拓展的。 实用函数 That 通过That可以获取守卫实例,这样您可以使用扩展函数为守卫进行扩展。 var guard = Guard.That; Requires 验证条件并在条件失败时抛出异常。 Guard.Requres<ArgumentNullException>(arg != null, $"Argument {nameof(ar
本文向大家介绍Rust 基本模式匹配,包括了Rust 基本模式匹配的使用技巧和注意事项,需要的朋友参考一下 示例 如果我们没有涵盖所有情况,则会出现编译器错误: 我们可以使用_默认/通配符大小写,它匹配所有内容: 此示例将打印:
本文向大家介绍Rust 绑定模式匹配,包括了Rust 绑定模式匹配的使用技巧和注意事项,需要的朋友参考一下 示例 可以使用@以下方式将值绑定到名称: 这将打印:
本文向大家介绍vue2.0 实现导航守卫(路由守卫),包括了vue2.0 实现导航守卫(路由守卫)的使用技巧和注意事项,需要的朋友参考一下 路由跳转前做一些验证,比如登录验证,是网站中的普遍需求。 对此,vue-route 提供的 beforeRouteUpdate 可以方便地实现导航守卫(navigation-guards)。 导航守卫(navigation-guards)这个名字,听起来怪怪的
本文向大家介绍F# 当守卫让您添加任意条件时,包括了F# 当守卫让您添加任意条件时的使用技巧和注意事项,需要的朋友参考一下 示例