Google重磅发布Flutter For Web,剑指前端

Flutter自从诞生之日起就一直光环加身,发展的也是如火如荼。Web前端号今天就来盘一盘Flutter。大家都知道除了苹果和安卓系统,Flutter Web的出现直接染指前端,也显示Flutter对整个移动互联网的野心。下面让我们一步一步来认识Flutter以及Flutter Web,也让前端工程师知己知彼,打打预防针,别哪天人家跑过来抢饭碗,都不知道对方是谁,这就尴尬了。

前端Flutter

前端Flutter

什么是Flutter?

在回答问题之前,首先确保大家都知道,目前市面上的手机操作系统主要谷歌的安卓和苹果的IOS,如果一个公司要开发一个手机APP,为了覆盖全部的用户,就必须招各自的开发团队分别敲代码开发一个功能一样的APP,再分别投放到各自的应用市场进行推广,当然苹果的只有一个市场。

很明显,这对大部分中小企业来说,这个成本就高了。可以说天下小老板苦双系统久矣。于是乎能快速写一次代码整出个东西,放并且到两个系统都可以运行成为本能追求。

Flutter For Web

Flutter For Web

这不,谷歌来了,推出了Flutter。

Flutter是谷歌针对移动端推出的移动UI框架,通过它可以快速在安卓和IOS上构建高质量的原生用户界面,既然是UI框架,就说明Flutter的领地不在服务端,也是在客户端。其特点是:

能快速开发强大的UI,使用自己的高性能渲染引擎来绘制widget。Flutter能达到原生应用一样的性能完全免费、开源一言以蔽之,Flutter是一款移动应用程序SDK,包含丰富的框架、控件和一些工具,一次编码可以同时构建Android和iOS应用,并且可以达到和原生应用一样的性能。Flutter用Dart语言开发,即使之前没有移动开发经验,也能很快上手。

由于以上特点,现在越来越多的开发者和组织使用Flutter进行开发,Flutter正变得越来越流行。

Flutter Platform

但是,Flutter的野心可不只是IOS和Android这些移动端,默默在一边的Web首先被瞄上了,而其后还有桌面应用,以及物联网时代的嵌入式开发。远的不说,先说和前端工程师最相关的Flutter For Web。

那什么是Flutter For Web?

在2019年5月7日举办的Google IO 2019 开发者大会正式上,Flutter 发布了 1.5 版,新加入对 Web 端的支持,即 Flutter for Web。

Fltter for web其实是一种代码兼容的实现,它使用的仍然是基于标准的Web技术(HTML、CSS和JavaScript三件套)。对于Web, Flutter For Web直接将 Dart 代码编译为 JavaScript,在底层则用 HTML、CSS、Canvas 等实现一个新的引擎,这使得 Flutter 项目可以输出为 Web 应用(注意底层Dom实现不了的部分用Canvas来代替)。而且Flutter本身的所有特点都可以被使用起来,并且是不需要安装任何浏览器插件。

就框架来说,Flutter For Web就是在Flutter的基础上,添加了对Web的支持。这里面的关键是在标准浏览器API之上实现Flutter的核心绘图层。Flutter For Web在Dart中完全实现了这个核心绘图层,并使用Dart编写的的JavaScript优化编译器将Flutter核心和框架与应用程序一起编译成一个可以部署到任何Web服务器上的单一的、小型化的源文件。Flutter For Web使用DOM、Canvas和CSS的组合,提供跨现代浏览器的可移植、高质量和高性能的用户体验。

Flutter For Web 框架

从框架来看,如果你已经用Flutter开发了IOS和安卓应用,甚至不用变动Flutter API就可以完全可以将UI代码从该应用中移植到Web,而这只需要重新实现一下引擎和嵌入层。

这就几乎实现了一边编写,到处运行,不论是封闭的IOS,还是开源的安卓,甚至是无处不在的Web,这也验证了Flutter 的发展目标:从移动端扩展到 Web 端、桌面端以及嵌入式设备,并希望它最终成为最好的“全平台” UI 框架。

Flutter与前端开发

Flutter与前端开发

前端工程师的挑战

上面提过了,Flutter是一种“客户端”技术,而客户端听起来不就是前端的阵地吗?

虽然目前Flutter For Web项目本身还处于技术预览状态,但随着更多限制的接触和问题的持续解决,Flutter的优势将会越来越明显。Flutter 已逐渐成为知名技术社区 Linkdein 和 StackOverflow 上的热门话题。

但对于前端的来说,Flutter对目前现有的前端技术不是通过颠覆或者淘汰,有点像降维打击,直接把前端的位置往“后端”给挤了挤。

首先Flutter可不是前端工程师熟悉的技术,并且在学习这门新武器的时候,前端毫无优势可言,Flutter Web的推出,真有些让前端工程师担心会丢了工作,因为失去竞争力而失业。

怎么办?

学起来

既然Flutter可以做这么多事情,就把他当作一门前端技术学起来呗,谁让你在入了互联网这个行当呢!

其实如果前端学的还可以的话(主要是指JS那块一定要强),学习Dart语言还是有一定有优势的,而且因为仍然在“客户端”这个阵地,其实还可以把前端工作中积累的一些经验继续发挥出来,这也是前端的优势所在。

总之,面对挑战,唯有树立信心,沉下心来学习,并最终把它拿下,才是王道。

参考:### Web前端号:前端们又要失业了?Google重磅发布Flutter For Web,剑指前端

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349