苹果发布全新 SwiftUI 框架:一次编码,五端通用

阅读数:8981 2019 年 6 月 4 日

在今天的 WWDC2019 上,Apple 推出了一个全新的 SwiftUI 框架,这是一个现代化的 UI 界面编码结构,它是从头开始构建的,以利用 Swift,让开发者感到惊讶。新框架使用声明性范例,让开发者用更少的代码编写相同的 UI。另外,SwiftUI 在 Xcode 中启用实时 UI 编程环境,实时看到编码的页面效果。最令人开发者尖叫的是,实现一次编码,可适应五端 Apple 产品平台。

应用更完美,代码更少

SwiftUI 是一种非常简单的创新方法,可以利用 Swift 的强大能力在所有苹果设备平台上构建用户界面。通过 SwiftUI,开发者仅使用一组工具和 API 就能为所有苹果设备构建用户界面。SwiftUI 使用易于阅读和编写的声明式 Swift 语法,可与新的 Xcode 设计工具无缝协作,使你的代码和设计完美同步。SwiftUI 自动支持动态类型、黑暗模式、本地化和可访问性,你的 SwiftUI 代码将成为你写过的最强大的 UI 代码。

声明式语法

SwiftUI 使用声明式语法,开发者可以简单地声明你的用户界面要做的事情。例如,你可以声明你要加入一个包含文本字段的项目列表,然后描述每个字段的对齐方式、字体和颜色。你的代码将比以前更简洁易读,节省你的时间并简化维护工作。

这种声明式风格甚至适用于像动画这样的复杂概念。只需几行代码就能轻松将动画添加到几乎任何控件中,并为其选择一系列现成效果。在运行时,系统会处理创建平滑移动所需的所有步骤,甚至可以处理中断以保持应用稳定。现在加入动画变得如此简单,你就能寻找新的方法让应用变得更加生动有趣。

设计工具

Xcode 11 提供了新的直观易用的设计工具,现在使用 SwiftUI 构建界面就像拖放一样简单自如。当你在设计画布中工作时,你编辑的所有内容都与相邻编辑器中的代码完全同步。键入代码时会即时显示预览效果,对该预览所做的任何更改都会立即反映在代码中。Xcode 会实时重新编译你的更改,并将其插入到应用的运行版本中,始终可见且可编辑。

拖放:只需拖动画布上的控件即可在用户界面中排列组件。单击打开检查器以选择字体、颜色、对齐方式和其他设计选项,并使用光标轻松重新排列控件。其中一些可视化编辑器也可以在代码编辑器中使用,因此就算你更喜欢手写部分界面代码,也可以使用检查器为每个控件发现新的修改器。你还可以从库中拖动控件并将其拖放到设计画布上或直接放在代码上。

动态替换:Swift 编译器和运行时完全嵌入到 Xcode 中,因此你的应用将不断构建并运行。你看到的设计画布不仅仅是用户界面的模拟——它就是应用的实时效果。Xcode 可以直接在你的实时应用中使用“动态替换”交换编辑过的代码,这是 Swift 中的一项新功能。

预览:现在你可以为任何 SwiftUI 视图创建一个或多个预览,以获取示例数据并配置几乎所有用户可能看到的内容,诸如大字体、本地化或黑暗模式。预览还可以显示你的 UI 在任何设备和任何方向上的效果。

原生支持所有苹果设备平台

SwiftUI 基于苹果数十年来创建世界上最直观,最具创新的用户界面的经验打造。苹果生态系统上所有用户喜爱的内容,例如控件和平台专属体验等,都会在你的代码中优雅呈现出来。

SwiftUI 是真正的原生代码,因此你的应用程序可以通过少量代码和交互式设计画布直接访问每个平台的成熟技术。

上手体验

这里有一系列教程和文档,提供手把手指导和深度教学:
SwiftUI 教程:https://developer.apple.com/tutorials/swiftui/
SwiftUI 文档:https://developer.apple.com/documentation/swiftui/

查看英文原文:https://developer.apple.com/xcode/swiftui/

收藏

评论

微博

发表评论

注册/登录 InfoQ 发表评论

最新评论

当场就吓脲了 2019 年 06 月 11 日 11:30 0 回复
前端开发要GG了?
Rone 2019 年 06 月 05 日 10:56 1 回复
移动前端的福音啊
Alan 2019 年 06 月 04 日 17:48 1 回复
👍🏻
没有更多了