迷茫是什么,迷茫就是大事干不了,小事不想干,能力配不上欲望,才华配不上梦想。

150+Flutter组件详细介绍地址:http://laomengit.com/

前言

我在Flutter未正式发布之前就开始学习了,因为Fuchsia系统,随着5G的发展,物联网将会迎来爆发式的增长,目前的市场上还没有一款物联网系统占据主导地位,虽然Google没有说Fuchsia是为物联网而生,但你理解Fuchsia系统的特性你就会明白此系统非常适合物联网,因此Flutter的发展前景不可限量。

在学习Flutter的过程中,中文资料非常少,官方的文档比较晦涩难懂,而且没有相关demo,这就是此网站诞生的初衷,希望能够帮助广大Flutter初学者,这里没有高深的技术,有的只是一个个控件的基础用法。

目前已经整理了150+的组件,而且将相近的组件放在了一起,比如Button组件,系统提供了10多种Button类组件,虽然索引是按照字母排序的,但不管你看哪一个Button,都可以看到其他Button的相关用法。

Flutter官方提供的Widget超过了300,个人的精力实在有限,如果你也希望帮助到别人,欢迎投稿,将会在其底部展示作者以及作者博客地址。

欢迎大家加入Flutter交流群(微信:laomengit)或者扫描下方二维码:

也欢迎大家关注我的公众号【老孟程序员】,文章及相关资源(正在准备控件的PDF以及大量相关demo)会在公众号首发,扫描关注:

未来规划

  1. 此网站的移动端已经在开发了,到时可以从手机上学习相关知识。
  2. 虽然Flutter是一个UI框架,但仅仅是UI是无法构成一个完整的App 的,因此下一步重点是介绍功能性的技术,比如网络加载数据、保存数据、混合开发等。
  3. 小demo的开发,我也在写一个大而全的项目还是小而精的项目上思考了很久,最后我选择了小而精的项目,原因是小的项目可以让大家更快的关注到重点,适合学习,比较大的项目比较难以入手。

Flutter会不会火?

我收到了很多关于要不要学Flutter?Flutter会不会火的问题?说实在我也不知道,任何事物的发展壮大天时地利人和缺一不可,技术本身优势仅仅是最基本的一个方面,我只能说Flutter的概率比较大而已,就像你和马云的儿子谁更有希望成为亿万富翁一样,我只能说Flutter的发展前景不可限量。

其实很多东西的学习,尽快入坑学习、动手实践远比畏畏缩缩、进度停留了解阶段要好得多,这是一个很简单的道理,可是偏偏很多人不明白或者做不到。如果你可以做到这样,不得不说这也是一种优势。

Flutter的使用情况

我知道你一定非常关注目前各个公司使用Flutter的情况,尤其头部互联网公司,据我所得到的消息(当然我也在头部互联网公司)目前各大互联网公司的头部App基本很少使用,为什么?原因很简单,

  1. Flutter从正式发布至今才2年,到底如何谁心里也没底,能不能禁得住市场的考验都是一个未知数。
  2. Flutter目前的包体积居高不下,头部App对包体积要求非常严格,都是以KB为单位的,即使一个空的Flutter项目都好几“MB”。

虽然头部App使用很少,但都在内部项目或者次级项目尝试Flutter。

小公司和个人开发者目前使用Flutter技术的非常多,没有进入过跨平台开发的人永远体会不到跨平台开发的便利,跨平台开发的人很难在回到原生开发了,除非你是为了五斗米折腰。

记住跨平台开发是历史趋势,从当初的H5到React Native,在到现在的Flutter,都是为了解决跨平台开发,提高开发效率,历史的车轮不会停止,即使不是Flutter,也会出现另一个Flutter。

关于Flutter版本

Flutter发展速度之快超乎你的想象,在查资料的时候注意版本,旧的版本在新的版本可能已经废弃了,尤其在混合开发方面。因此本站所有的文章如无特殊说明,Flutter版本及Dart版本如下:

  • Flutter版本: 1.12.13+hotfix.5
  • Dart版本: 2.7.0

如何学习Flutter

本站虽然整理了150+的控件基本用法,以后也会继续完善,但并不是让你每一个都学习一遍,任何技术基本都是掌握20%就可以解决80%的问题,因此我整理了一些常用控件,只需学会这些基础控件就可以上手项目了,至于其他的控件只需大概浏览一下,做项目的时候遇到一些功能能够想起Flutter已经提供了此组件就可以了。

关于Dart语言,如果你有其他高级语言的基础,比如Java,可以不用特意去学Dart基础,更着别人的代码敲,很快就可以掌握了。

最近也在整理学习Flutter的思维导图,等整理好了分享给大家。

开发环境建议

俗话说的好“磨刀不误砍柴工”,一款好的IDE可以极大的提高开发效率,个人建议使用mac(系统)+Android Studio。原因如下:

  • 既然使用了Flutter,那么开发的项目应该是移动端App,Flutter的打包最终依然是原生的应用程序。
  • Flutter在Android上调试的时候会遇到各种编译不通过的问题,这些需要一些Gradle的基本知识,因此建议使用Android Studio,理解基本编译过程。
  • Android编译不过一般是gradle版本、support版本和androidx的问题,这些问题在Android Studio上更好解决。

平时调试的时候可以使用Android Studio+IOS的模拟器进行调试。

开发环境的安装最好按照Flutter官网的步骤来,网上的介绍很可能版本比较老了。

第三方库的使用

在学习阶段建议大家少用第三方库,尤其是一些UI库、状态管理和路由管理的库,这里并不是说这些库不好,这些库很好,是大牛的智慧的结晶,如果你没有经过原生的开发,不了解开发的痛点,你永远无法了解这些库带给你的好处,而且如果这些库一直有人维护那还好,一旦没人维护,出了问题那解决起来可能更麻烦。

那是不是都不用第三方库呢?并不是绝对的,比如网络请求库dio,严格的说这不是Flutter的库,而是Dart的库,此库已经非常稳定。还有涉及大量原生开发的库,原生开发并不是你关注的重点,这些库是可以用的,但要了解Flutter与原生开发的通信机制。

吐槽一下

千万不要和别人说Flutter的UI编写太不好维护了,为什么?因为嵌套啊,我就想问问你你平时一个函数会写1000行吗?你写代码不会封装吗?平时的模块化思想都哪去了?不管H5,还是Android、IOS的UI开发哪一个不是“树”结构。

150多个Flutter组件详细介绍送给你的更多相关文章

  1. React组件详细介绍及其生命周期函数

    组件的详细说明 通过Reac.createClass({...})创建组件的时候,应该有一个render()方法,也可以在其中添加生命周期函数. render方法 当调用该方法的时候,会检测this. ...

  2. YARN组件详细介绍

    一.ResourceManager 内部主要有两个组件: 1.Scheduler:这个组件完全是插拔式的,用户可以根据自己的需求实现不同的调度器,目前YARN提供了FIFO.容量以及公平调度器.这个组 ...

  3. 微信小程序 icon组件详细介绍

    这些是提供的所支持的图标样式,根据需求在此基础上去修改大小和颜色. 主要属性: 使用方式: wxml <!--成功图标--> <icon type="success&quo ...

  4. Flutter 目录结构介绍、入口、自定义 Widget、MaterialApp 组件、Scaffold 组件

    Flutter 目录结构介绍 文件夹 作用 android android 平台相关代码 ios ios 平台相关代码 lib flutter 相关代码,我们主要编写的代 码就在这个文件夹 test ...

  5. <react> 组件的详细介绍:

    <react> 组件的详细介绍: 思维导图: 代码介绍: TodoList:(组件) import React, { Component } from 'react' import Sty ...

  6. 柯南君:看大数据时代下的IT架构(2)消息队列之RabbitMQ-基础概念详细介绍

    一.基础概念详细介绍 1.引言 你是否遇到过两个(多个)系统间需要通过定时任务来同步某些数据?你是否在为异构系统的不同进程间相互调用.通讯的问题而苦恼.挣扎?如果是,那么恭喜你,消息服务让你可以很轻松 ...

  7. Cloudera Manager (centos)安装详细介绍

    文章全部来自:Cloudera Manager (centos)安装详细介绍http://www.aboutyun.com/thread-9190-1-1.html(出处: about云开发) 这里已 ...

  8. Tkinter 控件详细介绍

    Tkinter 控件详细介绍 1.Button 按钮.类似标签,但提供额外的功能,例如鼠标掠过.按下.释放以及键盘操作/事件 2.Canvas 画布.提供绘图功能(直线.椭圆.多边形.矩形) ;可以包 ...

  9. kvm详细介绍

    KVM详解,太详细太深入了,经典 2016-07-18 19:56:38 分类: 虚拟化 原文地址:KVM详解,太详细太深入了,经典 作者:zzjlzx KVM 介绍(1):简介及安装 http:// ...

随机推荐

  1. python二叉树及叶节点获取 (面试题)

    才疏学浅,智商不够,花了一晚上看了二叉树.记录一下: 1.二叉树的遍历 前序遍历:根节点->左子树->右子树 中序遍历:左子树->根节点->右子树 后序遍历:左子树->右 ...

  2. 无人工地,原来是靠AI这样运行的

    随着全世界逐渐进入老龄化社会,适龄工作人口将急剧减少,必然导致用工成本增加,施工方降低人工成本.提升施工效率和质量的需求会越来越强烈,数字化施工技术应用前景广阔.在过去的十年中,无人机迎来了自己发展的 ...

  3. python基础函数、方法

    python的函数和方法,通过def 定义: 函数的特性: 减少重复代码 使程序变的可扩展 使程序变得易维护 函数和方法的区别:函数有返回值.方法没有 语法定义: def sayhi():#函数名 p ...

  4. 来自ebay内部的「软件测试」学习资料,覆盖GUI、API自动化、代码级测试及性能测试等,Python等,拿走不谢!...

    在软件测试领域从业蛮久了,常有人会问我: 刚入测试一年,很迷茫,觉得没啥好做的-- 测试在公司真的不受重视,我是不是去转型做开发会更好?  资深的测试架构师的发展路径是怎么样的?我平时该怎么学习? 我 ...

  5. 一天速成Python教程

    一.Python基础 Python是对象有类型,变量无类型的动态类型语言,追求简单优雅易读.可以在终端中逐行运行,也可以编写成大型的面向对象的工程.在开始写之前,注意Python 2.X中,开头要写上 ...

  6. 达拉草201771010105《面向对象程序设计(java)》第十周学习总结

    达拉草201771010105<面向对象程序设计(java)>第十周学习总结 实验十  泛型程序设计技术 实验时间 2018-11-1 第一部分:理论知识        泛型:也称参数化类 ...

  7. Python学习笔记--gevent嵌套使用

    这篇主要是接着上篇的,实验gevent嵌套使用,看情况如何.还是先上代码. #!/usr/bin/env python # -*- coding: utf-8 -*- # @Date : 2020-0 ...

  8. 93-time模块

    目录 time模块 一.time模块 1.1 时间戳 1.2 格式化时间 1.3 结构化时间 1.4 不同格式时间之间的转换 1.5 其它用法 time模块 一.time模块 import time ...

  9. JavaScript,ajax与springboot之间的传参方式

    Springboot:@PostMapping("/mDelTest")public String mDelTest (@RequestBody List<String> ...

  10. Vue+Axios+iview+vue-router实战管理系统项目

    项目实现登陆验证,iviewui组件使用,vue-router路由拦截,在删除登陆存储的token后,直接路由进登陆页面,实战数据请求,本地data.json,笔者也是初出茅庐,在项目运行后,会一直c ...