首發連接html
讓咱們一塊兒來了解Flutter與其餘跨平臺框架的優點,以及這些優點在開發流程中的做用。git
Flutter是什麼
就我目前的職業開發生涯中,目擊了太多太多項目不知道該選擇哪一種跨平臺方案的例子。這些項目都是不一樣的,可是咱們都但願這些項目可以運行在更多平臺和更多設備上,常見的做法就是在不一樣的客戶端招聘不一樣的開發人員來進行開發工做,好比手機端有iOS程序員和Android程序員等等。
我記得在2013年,我第一次看到了比較完善的跨平臺遊戲開發方案,那時候我就在想,爲何App端沒有這種工具能夠知足咱們跨平臺的需求呢?
可是,如今咱們有了,它就是Flutter!我將在下面介紹我使用Flutter作了些什麼,但願能對你有所幫助或啓發。
我有過一些iOS開發經驗,也有過一些遊戲開發經驗,能夠說Flutter就是我一直在尋找的跨平臺解決方案。它不只使用簡單,還能保持跨平臺UI的一致性時,而且很容易的與原生進行交互。是很是好的體驗。
Flutter的優點
你以前可能會了解到,全部的跨平臺框架都會在節約開發時間上有所幫助。可是,Flutter在有些地方跟其餘框架有不少不一樣,讓咱們來看看,究竟Flutter比其餘跨平臺框架在哪些地方作的更好。程序員
React Navite 的渲染過程看起來像是在每一個平臺上都很簡單。可是從圖中咱們不難發現,這種渲染過程須要依然各個平臺原生組件來進行渲染,React Native 就是幫咱們實現了對各個平臺應用層UI控件的映射。這就須要將每一個動畫每一個UI映射到各個平臺的動畫和UI上,顯然這比較繁瑣。
相比之下,Flutter不須要依賴熱任何平臺的UI組件就能生成UI界面。Flutter惟一須要的就是一個畫布,也就是咱們常說的Canvas。
下面是Flutter的渲染過程:
github
Flutter可以在任何平臺上構建徹底如出一轍的的UI,這種獨特的渲染方式是它脫穎而出的關鍵。
簡而言之,使用Flutter來實現UI和業務邏輯可以節省時間和精力,而且同時不影響最終產品的性能。原來iOS、Android須要每一個平臺都要配備相應的程序員,使用Flutter只須要一組程序員就能夠了,還節省了程序員!瀏覽器
總而言之,使用Flutter來開發,咱們能夠繞過幾個程序開發過程當中比較耗時的步驟,這樣使整個開發過程更快,更簡單且更省心。框架
一樣的,使用Flutter生成動畫更加靈活和通用,而且不會額外增長工做量。過渡動畫、圓角、顏色、陰影、變換等,Flutter都能輕鬆實現。
這裏給你們提供更多的Demo。讓咱們更好的熟悉這些動畫。ide
可以很容易與原生進行交互
除了UI以外,咱們還有不少功能須要依賴原生的支持,好比獲取GPS信息,藍牙通訊,傳感器,照相機,相冊等等。這些功能均可以經過Flutter的插件來實現。
固然有些時候這些插件也是不足以知足咱們的需求。可是不用擔憂,Flutter使用的開發語言(Dart語言)與原生代碼通訊很是簡單。只須要幾行代碼咱們就能夠實現原生與Flutter之間的交互,就能夠實現任何你想調用原生功能的需求。
交互流程以下圖:
工具
下面是演示視頻:
點擊這裏查看佈局
官方的這一操做,意味着Flutter從移動開發框架升級到了全平臺開發框架的行列。
若是咱們不須要在移動端作部署和使用,技術嫺熟的Flutter程序員可讓Flutter在熱門平臺上運行,包括但不限於Android、iOS、Web瀏覽器、Windows、macOS、Linux甚至是嵌入式設備。一樣的代碼能夠在這些任何平臺上運行,且不須要修改任何Dart代碼。性能
從業務層來看,Flutter是一個好的選擇嗎?
是的!是的!是的!
軟件產品能保證性能和穩定性、人員容易招聘、產品可以快速的迭代和開發這些優點都可以給企業帶來巨大的價值。一旦技術方案出現缺陷和存在任何方面的問題,都會給企業帶來直接或間接的損失。
從這個角度來看,Flutter都是能夠下降咱們的風險的:
爲何要嘗試使用Fultter?
讓咱們總結一下Flutter的最突出優勢:
因此說,想開發跨平臺的,性能優良的應用,Flutter是不二選擇。Flutter正式成爲最終的跨平臺UI框架只是時間問題。