AsyncDisplayKit 系列教程 —— 为什么要使用 AsyncDisplayKit

转载 2017年01月31日 15:56:42

前言

AsyncDisplayKit 是 Facebook 在 2014 年开源的一个异步界面渲染库,她是构筑于 UIKit 之上的一个封装库,与 UIView 是平级的关系(同时提供 UIView bridge 接口)。

AsyncDisplayKit 在开源社区历经一年多时间的琢磨,已经逐趋成熟,完全可以用于生产环境,但目前将 AsyncDisplayKit 用于生产环境的应用寥寥无几,究其原因,不外乎以下几点:

  • 不支持 IB,不支持 Autolayout,也不支持 Autoresizing,一切布局都需要手动计算完成;
  • 接口并非与 UIView 完全一致,对入门使用者来说,有一定的学习成本;
  • AsyncDisplayKit 并不是非用不可,她所追求的是极限用户体验。

为此, 我们可以引申出问题, 为什么要使用AsyncDisplayKit 

什么情况下应该使用 AsyncDisplayKit

  • 复杂的界面
  • 存在滑动性能问题的界面,同时使用各种方法优化无效的界面
  • 频繁更新的TableView(比如聊天界面)

什么情况下不应该使用 AsyncDisplayKit

  • 不存在性能问题的界面,没有必要使用 AsyncDisplayKit

性能问题的探讨

当我们谈论性能问题的时候,我们只是关注UI性能问题,那些逻辑、网络的性能问题并不是我们要关注的重点。

作为iOS开发者而言,务必需要了解到,有什么因素会影响UI性能。

就一般应用而言,需要关注的性能的UI控件可能就只有 UITableView 和 UICollectionView,其它类型的UI,性能问题在可以容忍的范围内。 这也是 什么情况下应该使用 AsyncDisplayKit 的关注点。

但是,我们仍然有必要去列出一些影响流畅性的关键点。

  • 网络请求,大部分网络请求都应该使用后台线程完成,如果你使用的是 AFNetworking、 SDWebImage 这些开源缓存库,那么切换到后台去请求网络资源的操作都已经默认完成。

  • 本地数据读写和计算,当你需要从闪存中读取文件的时候,这些操作都应该使用GCD或者NSThread切换至后台线程中完成。

  • 图像的处理,尽量使用合适的UIImage给予UIImageView使用,何谓合适?已经提前剪裁、缩放好的图片是最佳的,否则当UIImage赋予UIImageView.image的时候,iOS会有不必要的计算开销,而这些开销却是可以提前手动缓存起来的。

  • Layer 属性的谨慎选择,不合理的 Layer 特效(阴影、圆角)都会使流畅的滑动变成卡顿(非常重要)。

  • 少用 UIView.backgroundColor = UIColor.clearColor(),透明的背景会加剧卡顿。

  • 文字的渲染,你可能不知道,文字的渲染也是需要开销的。一般来说,文字渲染的开销非常小,甚至不能察觉到。但是,当一个UILabel被赋予大段富文本文字后,开销就会非常大。

  • 图像的渲染,一个任何开发者、几乎所有库(包括SDWebImage)都无法解决的问题,图像在UIImageView中的渲染开销,并且图像的渲染只能在主线程中执行。

前五点都是可以在 UIView 的基础上解决的,如果前五点均优化完成后,仍然无法解决卡顿问题,则应该使用 AsyncDisplayKit。

AsyncDisplayKit 有对应的方案,着力解决文字渲染、图像渲染两个难题。

下一篇教程,将指引你集成 AsyncDisplayKit 并编写一个简单的 Demo 界面。

转:http://www.jianshu.com/p/9e517e985145

AsyncDisplayKit 2.0 Objective-C 教程

集成 AsyncDisplayKitAsyncDisplayKit 官方只支持 CocoaPods 和 Carthage 安装。Carthage 不用说了,它是 Swift 包管理器。以国内的网络状况...
  • kmyhy
  • kmyhy
  • 2017年02月18日 10:26
  • 3121

iOS 保持界面流畅的技巧

文章转自:http://blog.ibireme.com/2015/11/12/smooth_user_interfaces_for_ios/ 这篇文章会非常详细的分析 iOS 界面构建中的各种性能...
  • chaoyuan899
  • chaoyuan899
  • 2015年11月19日 09:41
  • 6641

AsyncDisplayKit2.0教程(上)

原文:AsyncDisplayKit 2.0 Tutorial: Getting Started 作者: Luke Parham 译者:kmyhy “Art is anything you...
  • kmyhy
  • kmyhy
  • 2017年01月20日 17:18
  • 3570

AsyncDisplayKit源代码解析-整体(一)

前言本文简书地址:http://www.jianshu.com/p/21f3d46b1bc5 本文的中文注释代码demo更新在我的github上。AsyncDisplayKit 是 Facebook...
  • game3108
  • game3108
  • 2017年01月10日 18:47
  • 598

AsyncDisplayKit 系列教程 —— 集成、示例

集成 集成 AsyncDisplayKit 非常简单,使用 CocoaPods 添加 pod "AsyncDisplayKit" 然后 pod update 就可以了。什么?你还不愿意使用 Co...
  • quanqinayng
  • quanqinayng
  • 2017年01月31日 15:57
  • 1837

AsyncDisplayKit2.0教程(下)

AsyncDisplayKit 2.0 Tutorial: Automatic Layout 原文:AsyncDisplayKit 2.0 Tutorial: Automatic Layout ...
  • kmyhy
  • kmyhy
  • 2017年02月03日 13:01
  • 2145

AsyncDisplayKit入门指南

Facebook前两天发布了其iOS UI框架AsyncDisplayKit(ASDK)1.0正式版,这个框架被用于Facebook自家的应用Paper中,能够提高UI的流畅性并缩短响应时间。 下载...
  • likendsl
  • likendsl
  • 2015年03月05日 17:11
  • 3858

用 AsyncDisplayKit 開發響應式 iOS App

原文:Using AsyncDisplayKit to Develop Responsive UIs in iOS 作者:ZIAD TAMIM 譯者:kmyhy 在 2011 年,我認識了...
  • kmyhy
  • kmyhy
  • 2017年02月12日 08:44
  • 1653

iOS开源库源码解析之AsyncDispalyKit

来自Leo的原创博客,转载请著名出处我的stackoverflow前言 最近心血来潮,想研究下FaceBook的AsnycDispalyKit的源代码,学习一些界面优化的技术以及编码风格。这篇文章...
  • Hello_Hwc
  • Hello_Hwc
  • 2016年05月12日 15:25
  • 6073

AsyncDisplayKit使用详解

AsyncDisplayKit的核心组件包括: · ASDisplayNode 与UIView对应 —一个子类,用来自定义node。 ·  ASControlNode. 类似于UIControl ...
  • weixin_35755389
  • weixin_35755389
  • 2017年01月23日 13:51
  • 2002
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:AsyncDisplayKit 系列教程 —— 为什么要使用 AsyncDisplayKit
举报原因:
原因补充:

(最多只允许输入30个字)