当前位置: 首页 > news >正文

为什么我们应该使用 Flutter

作者 | 杜洁鹏

责编 | 唐小引

封图 | Flutter GitHub README

出品 | CSDN(ID:CSDNnews)

Flutter 是 Google 提供的新一代跨平台方案,随着 Google 在 IO19 宣布 Flutter 支持 Web 平台,就标志着 Flutter 已经全面持所有平台(目前 Windows 的只是早期预览版本,未来有可能会支持 UWP),它提供了非常友好的文档来帮助各端的同学迅速地进入到 Flutter 的海洋中。同时它的完全开源也让其有了更快的迭代,更好的生态。

感兴趣的同学可以关注 GitHub:https://github.com/flutter/flutter

01

Flutter 的优势

相比较目前的混合开发方案,Flutter 提供了大量的文档,能非常快速且友好的让你加入到这个大家庭。它并不止 WebView,也用通过解释 JS 后去操作系统的原生控件,Flutter 核心只有一层轻量的 C/C++代码(Engine),Flutter 在 Dart 中实现了其他大部分系统(组合、手势、动画、框架、widget 等),因此,开发人员可以轻松地进行读取、更改、替换或移除等操作。这为开发人员提供了对系统的巨大可定制性。

针对移动端,Flutter 提供了符合 Android 风格的 Material 和符合 iOS 风格的 Cupertino,同时对不同平台也做了不同的兼容,更好地保留了平台的特性,如 ScrollView,在 iOS 平台中,滑动的时候就拥有回弹的效果,在 Android 平台中,表现出来的就是阻尼的效果。当然,有的时候 Flutter 的 Framework 提供的 UI 格并不能满足我们的需求,我们还可以去自定义控件。

Flutter 在开发中支持 Hot Reload,相比较原生,这样的方式能更高效地开发,真正做到所写即所得。

02

Flutter 与 Native 通讯

使用平台通道在客户端(Flutter UI)和宿主(平台)之间传递消息。

Flutter Platform Channel

Flutter 定义了三种不同类型的 Channel,它们分别是:

  • BasicMessageChannel:传递字符串或半结构化信息;

  • MethodChannel:传递方法调用(method invocation);

  • EventChannel:数据流(event streams)通讯。

三种类型的 Channel 都定义在 platform_channel.dart 中,从源码中可以看到三种 Channel 都用到了以下三个属性。

  • name:String 类型,表示 channel 的名字,全局唯一;

  • codec:MessageCodec 或 MethodCodec 类型,消息的编码解码器;

  • binaryMessenger:BinaryMessenger 类型,用于发送数据。

name:

Flutter 中可能存在多个 Channel,Channel 之所以使用 name 来区分,当从 Flutter 端发送到 Platform 端时,需要传 channel name,之后通过 name 找到对应的 handle 来处理。

codec:

Flutter 定义了两种 Codec —— MessageCodec 和 MethodCodec,从而用来快速地编码和解码。

binaryMessenger:

虽然三种 Channel 各有用途,但是他们与 Flutter 通信的工具却是相同的,均为 BinaryMessager。

BinaryMessenger 是 Platform 端与 Flutter 端通信的工具,其通信使用的消息格式为二进制格式数据。当我们初始化一个 Channel,并向该 Channel 注册处理消息的 Handler 时,实际上会生成一个与之对应的

BinaryMessageHandler,并以 channel name 为 key 注册到 BinaryMessenger 中。当 Flutter 端发送消息到 BinaryMessenger 时,BinaryMessenger 会根据 channel 找到对应的 BinaryMessageHandler,并交由其处理。

Handler:

  • MessageHandler;

  • MethodHandler;

  • StreamHandler。

三种 handle 分别与三种 channel 对应,当我们向 channel 注册一个 handle 时,实际上就是向 BinaryMessager 注册一个对应 BinaryMessageHandler。当向 channel 发送消息时,就需要使用对应的 handle 来处理。

03

Flutter Packages 的操作

使用 Packages

Flutter 支持使用由其他开发者贡献给 Flutter 和 Dart 生态系统的共享软件包。您可以在 https://pub.dev/ 中查找。

之后需要在 pubspec.yaml 中进行添加:

dependencies:
    flutter:
        sdk: flutter

    im_flutter_sdk: ^1.0.0

之后执行 flutter packages get 下载。

开发的 package

用户也可以把自己开发的 Flutter package 并发布在 https://pub.dev/ 上。这里需要注意,如果开发的 package 需要使用第三方 sdk,比如您开发的 package 需要集成环信 Android 和 iOS 的 SDK,需要在对应的配置文件中添加对 SDK 的引用 ,如:

Android 需要在 build.gradle 中添加 Android SDK:

dependencies {
    api 'com.hyphenate:hyphenate-sdk:3.6.4'
}

iOS 需要在 podspec 中添加 iOS SDK:

s.dependency 'Hyphenate', '~> 3.6.4'

Packages 发布

发布前需要先检查:

pubspec.yaml
README.md
CHANGELOG.md

这三个文件最后会出现在 https://pub.dev/package 中包信息的展示页 ,请仔细确认。

之后执行校验:

flutter packages pub publish --dry-run --server=https://pub.dartlang.org

没有问题后执行发布:

flutter packages pub publish --server=https://pub.dartlang.org

此时会要求校验邮箱,把命令行中返回的 URL 粘贴到浏览器中,使用 Google Gmail 进行验证,校验后命令行中会提示校验成功,之后开始上传,等待上传结束后 package 就发布成功了。之后就可以在 pub.dev 中搜索到发布的。

04

结语

Flutter 作为新兴的混合开发解决方案,已经被广泛关注和使用,这不光是因为它有 Google 的支持,更因为它提供了更完善的文档和更高效的运行方式,开发者不必再把大量精力放到不同平台的展示上,更好的完成自己的业务,从企业管理者角度看,也大大降低了开发成本。

作者简介:杜洁鹏,从业 9 年,在环信负责 iOS 开发,专注于移动开发、VR 和摄影方向。

RECOMMEND

推荐阅读

《Flutter实战》

杜文 著

推荐语:“Flutter中文网”社区创始人倾力撰写的网红书《Flutter实战》正式出版。本书由浅入深,带领读者从0基础入门学习Flutter,到深入掌握Flutter进阶技能。以Github APP为实例,完整讲解如何开发APP。助你迅速成为一个高级的Flutter的开发者。

适读人群 : 本书适合Flutter初学者,对PC客户端、移动开发或Web前端开发有一定经验的读者,想更多了解Flutter、并进阶实战的技术人员阅读。

Flutter技术入门与实战 第2版

亢少军 著

 

推荐语:本书由资深架构师撰写,详细讲解Flutter的基本概念和使用技巧。既有基础知识,又有丰富示例,并包括详细案例的操作步骤,实操性强。还有配套网站提供了完整案例代码和视频课程,可帮助读者轻松掌握基础知识,快速进入实战。

本书在上一版的基础上,根据Flutter新版本对代码进行了全面更新,并增加了动画案例、插件理论和案例、Dio网络请求、Fluro企业级路由、Provider状态管理等内容,适合初学者全面掌握Flutter 。

往期精彩回顾

 4月书讯 | 一大波好书来袭,最美华章四月天

书单 | 怎样成为一名真正的数据科学家?这10本书就是答案
干货 | 企业级业务架构与“中台”的关系

相关文章:

  • 【收藏】机器学习入门的常见问题集
  • 为什么想进大厂,一定要掌握Java异步编程技术
  • 【第1期】MySQL为什么叫MySQL
  • 刘慈欣推荐!这本“疯狂的书”预言9年后人类将永生?
  • 4月6日 | Java异步编程在企业中的应用
  • 零基础掌握Istio on Kubernetes开发与运维
  • 聊聊流计算系统中的核心问题:状态管理
  • 我写了一本书,书名对肺活量大有益处
  • 大数据战略上升为国家战略,悄悄告诉你大数据大牛都在读的8本书
  • 灵魂拷问:你看过Xgboost原文吗?
  • 有图有真相——图神经网络到底是什么?
  • 聊聊XGBoost CatBoost LightGBM RF GBDT
  • 干货收藏!一文看懂8个常用Python库从安装到应用
  • 5G、物联网的加持下,区块链是否未来可期?
  • 大数据分析与挖掘——跟张良均老师学大数据
  • 230. Kth Smallest Element in a BST
  • Docker 笔记(2):Dockerfile
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • extract-text-webpack-plugin用法
  • HashMap ConcurrentHashMap
  • Javascript设计模式学习之Observer(观察者)模式
  • MQ框架的比较
  • SpringCloud集成分布式事务LCN (一)
  • storm drpc实例
  • Vim Clutch | 面向脚踏板编程……
  • Vue.js源码(2):初探List Rendering
  • 电商搜索引擎的架构设计和性能优化
  • 复杂数据处理
  • 高程读书笔记 第六章 面向对象程序设计
  • 每个JavaScript开发人员应阅读的书【1】 - JavaScript: The Good Parts
  • 使用API自动生成工具优化前端工作流
  • 微信开源mars源码分析1—上层samples分析
  • postgresql行列转换函数
  • 昨天1024程序员节,我故意写了个死循环~
  • ​iOS实时查看App运行日志
  • ​软考-高级-系统架构设计师教程(清华第2版)【第9章 软件可靠性基础知识(P320~344)-思维导图】​
  • ​云纳万物 · 数皆有言|2021 七牛云战略发布会启幕,邀您赴约
  • ​总结MySQL 的一些知识点:MySQL 选择数据库​
  • #LLM入门|Prompt#3.3_存储_Memory
  • #传输# #传输数据判断#
  • #前后端分离# 头条发布系统
  • (06)金属布线——为半导体注入生命的连接
  • (1)STL算法之遍历容器
  • (a /b)*c的值
  • (八)五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (二)JAVA使用POI操作excel
  • (附源码)spring boot建达集团公司平台 毕业设计 141538
  • (学习日记)2024.02.29:UCOSIII第二节
  • (一) springboot详细介绍
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • **登录+JWT+异常处理+拦截器+ThreadLocal-开发思想与代码实现**
  • .htaccess 强制https 单独排除某个目录
  • .net(C#)中String.Format如何使用
  • .NET/C# 的字符串暂存池
  • .NET导入Excel数据