微信号:frontshow

介绍:InfoQ大前端技术社群:囊括前端、移动、Node全栈一线技术,紧跟业界发展步伐。

开发者拍案叫绝!苹果发布全新Swift UI框架

2019-06-04 12:56 王强 译

源自 | Apple Developer
译者 | 王强
编辑 | 王莹
在今天的 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/

活动推荐

前端领域的技术演进一直要比其他技术快一些,这给前端工程师带来持续的挑战。这里整理了来自 Google、Oracle、阿里等工程师的干货课程,带你解读从前端小工到专家的实战心法,高效解决 80% 的开发难题。


 
前端之巅 更多文章 iTunes将死,苹果计划发布三款独立应用取而代之 Lightning Web组件霸气开源:基于最新的Web标准!可构建任何平台的Web应用 为什么2019年了我还在用jQuery 阿里云ARMS小程序监控进阶之路 Angular重大版本升级: 8.0正式发布!支持更多Web标准
猜您喜欢 软件测试完后,还有BUG,是测试人员的问题吗? 为更好服务社区,Docker 推出全新活动平台|航海日志 Vol.34 HAProxy负载均衡与最佳实践 浅谈动态跟踪技术之DTrace React Native的 Flex 布局简介