美文网首页
Flutter框架简要介绍

Flutter框架简要介绍

作者: jpchen_hn | 来源:发表于2017-09-26 16:38 被阅读0次

什么是Flutter?

Flutter is a mobile app SDK for building high-performance, high-fidelity, apps for iOS and Android, from a single codebase.

这是谷歌给Flutter的定义,可以看到,Flutter是面向iOS和Android应用,提供一套基础代码的高性能高可靠软件开发工具包,使开发者能够在iOS和Android两个最主要的移动平台上,打造统一代码的高性能应用,这是Flutter的主要目标

Flutter有什么优点

  • 高生产率
    • 一套代码可以开发出 Android 和 iOS 应用
    • Dart语言优越性,使得同样的功能只需要很少的代码。
    • 迭代更加方便, hot reload 功能
  • 创建优雅的、高度可定制的用户界面
    • Flutter 内置了对Material Design和Cupertino (iOS-flavor)的 UI 组件库
    • 提供了可定制的 UI 组件,不再受制于OEM控件的限制

Flutter架构

Flutter 系统架构

Flutter 分为两个部分,上层是函数响应式的Framework(开源),下层是Engine,可以这样理解,基于Framework开发App,在Engine里运行。

与RN的区别

Flutter 视图原理 RN 视图原理

Flutter将UI组件和渲染器从平台移动到应用程序中,这使得它们可以自定义和可扩展。Flutter唯一要求系统提供的是canvas,以便定制的UI组件可以出现在设备的屏幕上。Dart程序和执行数据编码和解码的原生平台代码(蓝色,适用于iOS或Android)之间仍然有一个接口,但这能比JavaScript桥接器快几个数量级。

Flutter 工程结构

官方推荐的集成开发环境是IntelliJ,工程的层次结构大致是这样的:

Paste_Image.png

可以看到,Flutter框架自动生成了android目录和ios目录,并且框架已经做好了粘合两种平台的连接代码,开发者只需要在lib目录用Dart语言,基于其Framework编写App,即实现了一套代码产生两个平台的App。其中:

  • Android:底层引擎是C++代码通过Android的NDK编译,上层通过Dart编译器编译,以native code方式运行
  • iOS:底层引擎是C++代码通过LLVM编译,上层通过AOT-compiled,也是以native code方式运行

Everything’s a Widget

Widget 是每个 Flutter 应用的基础。每个 Widget 是一部分用户界面上不可变的定义。和其他框架把 View、controller、 Layout 和其他资源分开定义不一样,Flutter 具有一致的、唯一的对象模型—— Widget:

  • 一个结构性的元素(比如 按钮或者菜单)
  • 一个元素的风格(比如 字体或者颜色)
  • 指定布局属性(比如 padding)
  • 也可以包含一些业务逻辑
  • 其他…

Widget 通过组合来组成层级结构。每个 Widget 都内嵌在父 Widget 中,并继承父 Widget 的属性。 并没有单独的 “application” 对象,根 Widget 扮演这个角色。Widget 可以响应用户事件来改变 UI,比如用户点击了一个按钮把一个 Widget 替换为另外一个 Widget。框架会比较变化前后 UI 的差异,并高效的更新 UI。

Paste_Image.png

部分FAQ

  1. Flutter引擎有多大?
    官网说最小是6.7MB,我新建一个最简单的demo,编译出来一共7.1MB,整个引擎的大小还算是比较小的
  2. “hot reload”是怎么做到的?
    hot reload 的原理是插桩,类似instant run,debug模式下,对每一个方法和成员进行插桩,运行时期reload就生效了,无需重新安装
    注意:全局变量初始化、静态成员初始化、main方法不能热加载。
  3. 是否可以在原来的基础上,使用Flutter继续开发?
    可以,不过需要修改一些东西,包括入口和相互调用(需待研究)
  4. Flutter是否有反射和依赖注入框架
    目前还没有
    ...

小结

Flutter以一种类似游戏引擎,提供通过类似游戏开发的方式,以一套代码生成Android和iOS平台两种应用,很大程度上减少了App开发和维护的资源,同时Dart语言强大的性能表现和丰富的特性,使得开发比较便利,但是Flutter目前还处于Alpha阶段,许多功能还不是特别完善,完全替代目前Android和iOS开发还有比较长的路要走。

参考

flutter官网
flutter github
Dart

相关文章

  • Flutter框架简要介绍

    什么是Flutter? Flutter is a mobile app SDK for building high...

  • Flutter框架分析(二)-- 初始化

    前言 上篇文章《Flutter框架分析(一)-- 总览和Window》介绍了Flutter框架最核心的渲染流水线和...

  • Flutter 动画详解(一)

    本文主要介绍了动画的原理相关概念,对其他平台的动画做了一个简要的梳理,并简要的介绍了Flutter动画的一些知识。...

  • 1. Flutter你想要的热更新之思路

    Flutter你想要的热更新之思路 1. Flutter 介绍 Flutter 是谷歌的移动 UI 框架,可以快速...

  • 00-跨平台开发之Flutter

    跨平台开发之Flutter 主要内容: 跨平台框架对比 Flutter介绍 Flutter快速入门向导 必备插件介...

  • Flutter 入门必会

    Flutter 官网介绍: Flutter中文网 Flutter是谷歌的移动UI框架,可以快速在iOS和Andro...

  • flutter widget 框架概述

    今天开始,我们开始系统的学习下flutter widget 框架 介绍 Flutter Widget采用现代响应式...

  • Flutter面试总结

    一、请简单介绍下Flutter框架,以及它的优缺点? Flutter是谷歌推出的一套开源跨平台UI框架,可以快速的...

  • Flutter 介绍 & 环境配置

    1 Flutter 介绍 Flutter 是 Google推出并开源的移动应用开发框架,主打跨平台、高保真、高...

  • Android周报十九期

    1)Google基于Dart的新移动开发框架Flutter介绍 Google基于Dart的新移动开发框架Flutt...

网友评论

      本文标题:Flutter框架简要介绍

      本文链接:https://www.haomeiwen.com/subject/bzcsextx.html