RN 轉小程序引擎 Alita V1.1.0 發佈

Alita在處理React語法的時候,採用了一種運行時處理JSX的技術,相對於社區現有的編譯時方案,在JSX語法的支持上更加完備,關於運行時處理JSX的原理,詳情請看html

1.0.0發佈以來,咱們收到了不少對於Mobx的支持的需求,另外Alita初始版本並不支持 watch模式(因爲內部和外部使用Alita的方式不一樣),這致使了每修改一個文件,須要看小程序效果的時候都須要從新執行一下alita命令,開發調試起來很不方便。 因此咱們在這個版本里面,主要作了兩件事情:Mobx支持,watch模式前端

支持mobx

Mobx自己並不和React綁定,能夠用於任何前端框架。可是它和React的配合,能夠方便的進行React應用的數據管理,Alita這個版本主要支持了Mobx的使用,得益於Alita運行時架構的設計,Alita存在一個嵌入式的mini-react,因此只需把Mobx和內嵌的mini-react正確鏈接起來,在AlitaMobx應該就能夠正常的使用。 react

參考mobx-react而且結合mini-react暴露的API,咱們在微信小程序端適配了一個wx-mobx-react。 Alita轉化完你的RN應用以後,會自動在小程序端把mobx-react切換爲wx-mobx-reactgit

在支持mobx的過程當中,咱們還有了另外的收穫,當咱們設置多個observable的值時候,mobx-react會經過unstable_batchedUpdates接口批量更新,據此Alita也對外提供了unstable_batchedUpdates接口,和React同樣這個接口會合並屢次setState,對應提高應用的性能頗有幫助。github

另外新版本以後Alita生成的js代碼可讀性會減低,以前Alita會生成ES6的代碼,而後經過微信小程序自帶的功能把ES6轉化爲ES5,可是微信小程序的轉化並不支持decorators(這個特性對於Mobx十分重要),因此如今Alita會經過babel直接生成ES5的代碼。redux

詳細文檔請看:支持mobx小程序

咱們還提供了一個實際的用Mobx構建的Demo微信小程序

watch

爲了簡化開發調試的過程,Alita 新增了 watch 功能,只須要在執行alita命令的時候,添加--watch參數便可。將來咱們也將不斷提高 Alita 的開發調試體驗。前端框架

其餘更新

  • 添加 forceUpdate API
  • 對外暴露 unstable_batchedUpdates 批量更新接口
  • 優化 Provider, 方便reduxMobxstore注入
  • 根據 react-redux 從新實現 alita redux連接庫
  • 添加 decorators轉化支持
  • 添加 --comp 命令行參數,適用於只轉化RN組件,而不是整個項目的場景
  • 其餘特性 具體請看 CHANGELOG

移步Github,進一步瞭解 Alita

相關文章
相關標籤/搜索