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

2019 年 6 月 4 日 前端之巅

源自 | 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% 的开发难题。


登录查看更多
0

相关内容

苹果公司在 WWDC 2014 开幕 Keynote 上发布的全新编程语言,具有更多现代化特性,同时容易使用,定位是补充 Objective-C. > Swift is an innovative new programming language for Cocoa and Cocoa Touch. Writing code is interactive and fun, the syntax is concise yet expressive, and apps run lightning-fast. Swift is ready for your next iOS and OS X project — or for addition into your current app — because Swift code works side-by-side with Objective-C.

Swift - Apple Developer

【2020新书】实战R语言4,323页pdf
专知会员服务
98+阅读 · 2020年7月1日
【2020新书】使用高级C# 提升你的编程技能,412页pdf
专知会员服务
56+阅读 · 2020年6月26日
【实用书】Python技术手册,第三版767页pdf
专知会员服务
229+阅读 · 2020年5月21日
【实用书】Python爬虫Web抓取数据,第二版,306页pdf
专知会员服务
115+阅读 · 2020年5月10日
【经典书】数据结构与算法C++,第二版,738页pdf
专知会员服务
165+阅读 · 2020年3月27日
【电子书】Flutter实战305页PDF免费下载
专知会员服务
20+阅读 · 2019年11月7日
重磅!Flutter 2019年最新进展和未来展望
前端之巅
4+阅读 · 2019年6月20日
用Now轻松部署无服务器Node应用程序
前端之巅
16+阅读 · 2019年6月19日
7 款实用到哭的App,只说一遍
高效率工具搜罗
84+阅读 · 2019年4月30日
支持多标签页的Windows终端:Fluent 终端
Python程序员
7+阅读 · 2019年4月15日
可能是 Android 上最好用的写作 App
少数派
10+阅读 · 2018年12月21日
Android P正式发布,你需要尽快做适配了
前端之巅
3+阅读 · 2018年8月7日
业界 | 谷歌发布自然语言框架语义解析器SLING
机器之心
3+阅读 · 2017年11月16日
Mesh R-CNN
Arxiv
4+阅读 · 2019年6月6日
Arxiv
9+阅读 · 2018年5月7日
Arxiv
13+阅读 · 2018年4月18日
Arxiv
3+阅读 · 2018年3月29日
VIP会员
相关VIP内容
【2020新书】实战R语言4,323页pdf
专知会员服务
98+阅读 · 2020年7月1日
【2020新书】使用高级C# 提升你的编程技能,412页pdf
专知会员服务
56+阅读 · 2020年6月26日
【实用书】Python技术手册,第三版767页pdf
专知会员服务
229+阅读 · 2020年5月21日
【实用书】Python爬虫Web抓取数据,第二版,306页pdf
专知会员服务
115+阅读 · 2020年5月10日
【经典书】数据结构与算法C++,第二版,738页pdf
专知会员服务
165+阅读 · 2020年3月27日
【电子书】Flutter实战305页PDF免费下载
专知会员服务
20+阅读 · 2019年11月7日
相关资讯
重磅!Flutter 2019年最新进展和未来展望
前端之巅
4+阅读 · 2019年6月20日
用Now轻松部署无服务器Node应用程序
前端之巅
16+阅读 · 2019年6月19日
7 款实用到哭的App,只说一遍
高效率工具搜罗
84+阅读 · 2019年4月30日
支持多标签页的Windows终端:Fluent 终端
Python程序员
7+阅读 · 2019年4月15日
可能是 Android 上最好用的写作 App
少数派
10+阅读 · 2018年12月21日
Android P正式发布,你需要尽快做适配了
前端之巅
3+阅读 · 2018年8月7日
业界 | 谷歌发布自然语言框架语义解析器SLING
机器之心
3+阅读 · 2017年11月16日
相关论文
Top
微信扫码咨询专知VIP会员