Flutter 不能做什么?

在评估新技术时,我发现弄清楚哪些不能做比哪些能做到的更有用,即使这些限制看起来非常消极。
准备迎接失望与不快吧。

我试图回避一些人们不喜欢的观点和事情(比如缺乏标记语言),只讨论关于 Flutter 目前无法做到的,以及何时有希望能做到。

从 Dart 直接调用原生 API

Flutter 可以与原生平台 API 交互 ,但不是直接调用。这与 Xamarin 及 NativeScript 不同,这两者都可以通过语言绑定,使用与编写 App 相同的语言来调用原生 API:

《Flutter 不能做什么?》 NativeScript和Xamarin可以直接访问原生 API

有什么影响?

大多数情况下影响很小,许多原生调用可能已经有人封装成插件供直接使用,如果没有插件,你就必须编写 Objective-C/Swift 或 Java/Kotlin 代码以与原生 API 交互,使用不同的
IDE,并通过平台通道(platform channel)进行通信。

后续会改变吗?

短期不会。

原生平台 View

Flutter 使用 Skia 渲染一切,但有时你需要使用原生 UI 元素,比如地图和 WebView。Flutter 确实支持内嵌这些 View,但仍处于预览版本而且存在相当多的问题。

有什么影响?

许多场景能够工作,但也有限制。目前最大的问题是原生的 Android View 不支持文本输入,因为无法显示软键盘。不过全屏的 WebView 是完全支持的,包括 Android 上的键盘输入。
Flutter 仓库下关于 Google 地图插件 , WebView 插件platform-views 的热门问题 (issues) 值得关注。

后续会改变吗?

是的,相关工作正在积极进行,应该会在 2019 年变得更好。

代码热更新

代码热更新允许开发人员无需通过常规的应用商店发布流程,而直接将补丁推送到他们的 App。这就可以在不发布新版本的情况下修改 Bug,从而实现像 Web 那样持续的迭代过程。像 React Native、Cordova 和 Ionic 等方案都支持,而 Flutter 不支持。

有什么影响?

Flutter App 所有更新都必须经过标准的应用商店发布流程,iOS 有时需要好几天。

后续会改变吗?

是的,目前正在开发,初期用于 Android,可以关注这个 issue 的更新。

密码自动填充

正如我之前所提及的,原生文本编辑组件是 Flutter 重制复杂度最高的组件,其中一个主要缺失的功能就是自动填充密码字段。

有什么影响?

用户无法使用 iOS 或 Android 的内置密码管理器,也无法使用 1Password 等第三方管理器登录你的应用。包括 iOS 12 能够从短信中快速插入一次性验证码。

《Flutter 不能做什么?》

后续会改变吗?

有希望。有几个关于它的开放特性请求。同时你可以在 iOS 上使用原生 Safari View Controller 显示支持自动填充的网页,但这远不够理想。

Lottie

Flutter 目前尚未完全支持 Airbnb 的 Lottie 框架,这是一种给 App 添加动画的流行方式。基于它设计人员可以使用 Bodymovin 插件从行业标准 Adobe After Effects 工具导出动画,然后直接导入到 iOS 和 Android App 中。
目前有一些插件可用,例如 lottie_flutter ,但它们仍有一些问题。

有什么影响?

当前插件可能无法完美呈现动画。另一种选择是使用 2Dimension 的 Flare,但大多数设计师都不熟悉它。

后续会改变吗?

也许吧。Flutter 的渲染引擎 Skia 在 2018 年增加了对 Bodymovin 文件的支持。但 Flutter 尚未提供此功能,不过已经有 issue 在跟踪这个问题了。

电视、手表和汽车

你不能使用 Flutter 为 tvOS、watchOS、CarPlay 或 Android Auto 构建应用程序。对 Wear OS(之前的 Android Wear)的支持也很有限。Flutter 必须添加 Bitcode 支持才能部署到 tvOS 和 watchOS。

有什么影响?

针对这些平台,你必须使用原生代码或其它替代框架来开发。

后续会改变吗?

可能。但可能需要一段时间。目前有 Issue 在跟踪这些问题: Bitcode support , car supportWear OS support

C/C++ 交互

许多语言都有外部函数接口来调用 C/C++ 库中的函数,这在 Dart 的世界里是不存在的。

有什么影响?

要使用非常流行的 SQLite 等库,你必须使用平台通道(platform channel),或使用类似 sqflite 之类的插件。

后续会改变吗?

是的。目前正在积极开展这方面的工作,但需要对 Dart 虚拟机做大量修改

结语

哦,希望这不是太令人沮丧。不过别担心,没有什么是完美的,Flutter 仍然很棒。
如果我遗漏了什么,请在评论中告诉我。

原文: https://medium.com/flutter-community/what-flutter-cant-do-limitations-ed185c89fb61
作者:Tom Gilder
编译:码王爷

    原文作者:码王爷
    原文地址: https://www.jianshu.com/p/4b08c0b64946
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞