您现在的位置是:首页 > Javascript
当前栏目
Swift 5.2 将 KeyPaths 用作函数
2023-03-07 09:50:09 时间
本文转载自微信公众号「Swift社区」,作者Swift社区。转载本文请联系Swift社区公众号。
Swift 5.2 的新功能之一:能够将 KeyPaths 用作函数。如果您只在闭包中返回某个 KeyPath 的值,这将非常有用。
在 Swift 5.2 之前:
- struct Student {
- let id: Int
- let name: String
- let age: Int
- let grade: Double
- }
- func getStudentsName(from students: [Student]) -> [String] {
- return students.map { $0.name }
- }
此代码使用 map(_ :) 通过将数组中的每个学生返回 $0.name 来将 Student 对象的数组转换为学生名字 String 数组,这是我们常用的一种写法。
在 Swift 5.2 中,可以写成(需要 Xcode 11.4 beta 以上):
- func getStudentsName(from students: [Student]) -> [String] {
- return students.map(\.name)
- }
这样的写法看起来非常清晰,也很简便。和 map(_ :) 一样 filter(_ :), reduce(_ :) 等函数也可以直接这样写,比如我们想获取所有年龄大于21岁的学生的名字数组。
- extension Student {
- var isTwentyOneOrOlder: Bool {
- return age >= 21
- }
- }
- func getStudentsName(from students: [Student]) -> [String] {
- return student.filter(\.isTwentyOneOrOlder)
- .map(\.name)
- }
写成这样并不是必须的,只是在某些情况能让代码看起来更简便,但是有时候则不然,所以可以根据需要选择是否使用。
相关文章
- 鲜为人知但很有用的 HTML 属性
- 翻转再翻转!有意思的水平横向溢出滚动
- 自定义计数器小技巧!CSS 实现长按点赞累加动画
- 过五关!React高频面试题指南
- 软件开发中的十个认知偏差
- 不需要 JS!仅用 CSS 也能达到监听页面滚动的效果!
- 一文读懂TypeScript类型兼容性
- Vue 的响应式原则与双向数据绑定
- 快速掌握 TypeScript 新语法:Infer Extends
- JWT教你如何证明你是我的人!
- 一篇带给你 V8 GC 的实现
- 面试官:请使用JS完成一个LRU缓存?
- 通过可视化来学习JavaScript事件循环
- 新的跨域策略:使用 COOP、COEP 为浏览器创建更安全的环境
- 为什么有人说 vite 快,有人却说 vite 慢?
- 种草 Vue3 中几个好玩的插件和配置
- 超全面的前端工程化配置指南
- Vue 状态管理未来样子
- Volatile关键字能保证原子性么?
- 面试突击:SpringBoot 有几种读取配置文件的方法?