从React到Flutter

自从去年底接触flutter到现在,陆续在学习相关的一些基础知识,具备React经验对flutter的学习有很大帮助,官网也对ReactNative开发者有专门的说明,本文对此讨论一下。

Component (React) vs Widget (Flutter)

在React中的Component概念在Flutter中对应概念称为Widget,都是为重用而生,也都分为有状态和无状态两类,前者内部维护state,后者则是纯渲染用的无状态组件。少了状态维护和脏状态判断以决定是否需要重新render,无状态组件自然轻量得多。

但React中无状态组件就是一个单纯的function,接收 props返回jsx,轻量到了极限,加上最新支持的hook,function component已经可以拥有自己的状态信息,完成本class component才具备的功能。而flutter中无状态组件stateless widget是个抽象类,跟statefull widget同继承自 Widget,stateless widget从build方法生成Widget,stateful widget则是从createState返回的State调用build方法生成Widget。


1. Widget类图

从上面图1可以看到类图继承关系和几个关键成员,注意上面两类箭头,空心箭头表示继承(is),线条箭头表示成员关系(has)。

Element -> Component -> Instance (React) vs Widget -> Element->RenderObject(Flutter)

React中Element是个plain object,简单轻量创建没什么成本,且不可变,用来描述组件的基本信息,包含组件的类型信息(简单的组件类型type就是字符串,比如 div, span;复杂的类型就是类或者方法),Component描述根据传入属性如何生成jsx,而component的instance则是React内部负责创建和销毁,用户不需要直接参与;

Flutter的Widget也是不可变对象,包含Widget的初始化属性信息以及状态信息(针对stateful widget),通过Widget的createElement方法可以创建Element对象,该对象代表Widget对象作为渲染树节点成员,存在Element的一个意义是,因为Widget不可变,则属性信息不变时候Widget可重用,对应渲染树上多个Element对象。Element的renderObject属性返回的RenderObject对象则是真正用于UI渲染的对象,RenderObject子类通过override paint方法实现Widget的UI的绘制。

-----回家啦,下次继续写----

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 国庆后面两天在家学习整理了一波flutter,基本把能撸过能看到的代码都过了一遍,此文篇幅较长,建议保存(star...
    Nealyang阅读 9,828评论 1 17
  • 目录 一、Flutter 为何使用Dart开发语言二、Flutter的UI系统1.特点2.架构简介2.1 Flut...
    十拿九稳啦阅读 9,187评论 3 28
  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 7,949评论 0 24
  • Flutter是如何使用Widgets、Elements和RenderObjects来实现如此令人惊艳的视觉效果的...
    Rreply阅读 9,382评论 1 13
  • HTML模版 之后出现的React代码嵌套入模版中。 1. Hello world 这段代码将一个一级标题插入到指...
    ryanho84阅读 11,430评论 0 9

友情链接更多精彩内容