亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

用WEB技術(shù)棧開發(fā)NATIVE應(yīng)用(二):WEEX 前端SDK原理詳解

ls0609 / 1278人閱讀

摘要:依舊采取傳統(tǒng)的開發(fā)技術(shù)棧進(jìn)行開發(fā),同時(shí)在終端的運(yùn)行體驗(yàn)不輸。首先來(lái)看下前端開發(fā)框架目前與構(gòu)成了三大最流行的前端開發(fā)框架,具有組件化以及三大特性,還學(xué)習(xí)的,引入了狀態(tài)管理模塊。

摘要: WEEX依舊采取傳統(tǒng)的web開發(fā)技術(shù)棧進(jìn)行開發(fā),同時(shí)app在終端的運(yùn)行體驗(yàn)不輸native app。其同時(shí)解決了開發(fā)效率、發(fā)版速度以及用戶體驗(yàn)三個(gè)核心問題。那么WEEX是如何實(shí)現(xiàn)的?目前WEEX已經(jīng)完全開源,并捐給Apache基金會(huì),我們可以通過(guò)分析其源碼來(lái)一探究竟。

點(diǎn)此查看原文:http://click.aliyun.com/m/43048/

作者:阿里-移動(dòng)云-大前端團(tuán)隊(duì)

傳統(tǒng)的移動(dòng)端開發(fā),一個(gè)完整的業(yè)務(wù)需要維護(hù)三份終端代碼:Android、iOS、H5,這帶來(lái)了極大的開發(fā)成本以及維護(hù)成本。尤其是對(duì)處于業(yè)務(wù)初創(chuàng)期需要快速試錯(cuò)的業(yè)務(wù)以及需要支持定期運(yùn)營(yíng)活動(dòng)的業(yè)務(wù)。所以業(yè)界也一直在探索跨平臺(tái)方案,旨在通過(guò)一套代碼完成各個(gè)終端的業(yè)務(wù)邏輯。相關(guān)方案經(jīng)過(guò)不斷演化,從早期的H5、Hybrid到如今的Cloud Native(云原生),在開發(fā)效率和用戶體驗(yàn)上都在一點(diǎn)點(diǎn)逼近最初的設(shè)想。

早期H5和Hybrid方案的核心是利用終端的內(nèi)置瀏覽器(webview)功能,通過(guò)開發(fā)web應(yīng)用滿足跨平臺(tái)需求。該方案可以解決跨平臺(tái)問題,同時(shí)可以提升發(fā)版效率。但其最大的弊端在于用戶體驗(yàn)相較于native開發(fā)的app存在較大差距,經(jīng)常出現(xiàn)頁(yè)面卡頓,加載慢等問題。

于是后來(lái)業(yè)界開始探索依舊利用web技術(shù)棧開發(fā)出媲美原生體驗(yàn)app的方案,于是以WEEX為代表云原生開發(fā)框架開始出現(xiàn)。所謂云原生(Cloud Native)指可以通過(guò)云端快速發(fā)布(與遠(yuǎn)程web應(yīng)用發(fā)布流程類似),同時(shí)還可以達(dá)到媲美原生App體驗(yàn)的方案。WEEX依舊采取傳統(tǒng)的web開發(fā)技術(shù)棧進(jìn)行開發(fā),同時(shí)app在終端的運(yùn)行體驗(yàn)不輸native app。其同時(shí)解決了開發(fā)效率、發(fā)版速度以及用戶體驗(yàn)三個(gè)核心問題。那么WEEX是如何實(shí)現(xiàn)的?目前WEEX已經(jīng)完全開源,并捐給Apache基金會(huì),我們可以通過(guò)分析其源碼來(lái)一探究竟。

WEEX框架主要分為兩部分:

1.前端JavaScript框架
2.Native SDK

在上一篇博客中,我們介紹了Native SDK的原理,本文主要介紹其前端JavaScript框架原理。

1 整體架構(gòu)
首先還是再來(lái)看下WEEX開發(fā)的整體架構(gòu):

可以看到在JS-Native Bridge將渲染指令發(fā)送給Android或者iOS渲染引擎之前,我們的業(yè)務(wù)代碼運(yùn)行在JSCore/v8的執(zhí)行引擎之中,而在該執(zhí)行引擎之中除了執(zhí)行業(yè)務(wù)JSBundle,還運(yùn)行著JS Framework,JS Framework不僅提供了jsbundle必要的運(yùn)行時(shí)環(huán)境,同時(shí)還提供了與native通信的接口。

而這個(gè)JS Framework就是我們今天介紹的重點(diǎn)。

這是前端框架的主要架構(gòu):

FRONTEND FRAMEWORK/DSL:這是WEEX的開發(fā)框架,目前WEEX主要是使用Vue.js進(jìn)行開發(fā)
WEEX-VUE-LOADER:前端編譯器,將vue文件編譯成es5代碼
WEEX-VUE-FRAMWORK:WEEX核心框架,主要負(fù)責(zé)將virtual dom轉(zhuǎn)換成weex的native dom api
WEEX-RUNTIME:負(fù)責(zé)與native渲染引擎對(duì)接,將native dom api轉(zhuǎn)換成對(duì)應(yīng)平臺(tái)(Android、iOS)的platform api,然后傳遞給native渲染引擎,由后者負(fù)責(zé)渲染工作。

2 Vue.js

首先來(lái)看下前端開發(fā)框架Vue.js,Vue.js目前與React 、 Angular構(gòu)成了三大最流行的前端開發(fā)框架,Vue.js具有組件化、virtual dom以及MVVM三大特性,還學(xué)習(xí)React的Redux,引入了狀態(tài)管理模塊Vuex。同時(shí)相比起React主要基于JSX,Vue.js的開發(fā)模式更加清晰,簡(jiǎn)單,上手速度更快。.vue 文件通??梢苑譃槿糠郑?template> 、

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/93084.html

相關(guān)文章

  • WEB技術(shù)開發(fā)NATIVE應(yīng)WEEX SDK原理詳解

    摘要:于是后來(lái)業(yè)界開始探索依舊利用技術(shù)棧開發(fā)出媲美原生體驗(yàn)的方案,于是以為代表云原生開發(fā)框架開始出現(xiàn)。依舊采取傳統(tǒng)的開發(fā)技術(shù)棧進(jìn)行開發(fā),同時(shí)在終端的運(yùn)行體驗(yàn)不輸。其同時(shí)解決了開發(fā)效率發(fā)版速度以及用戶體驗(yàn)三個(gè)核心問題。 摘要: WEEX依舊采取傳統(tǒng)的web開發(fā)技術(shù)棧進(jìn)行開發(fā),同時(shí)app在終端的運(yùn)行體驗(yàn)不輸native app。其同時(shí)解決了開發(fā)效率、發(fā)版速度以及用戶體驗(yàn)三個(gè)核心問題。那么WEEX...

    nanfeiyan 評(píng)論0 收藏0
  • 開源中國(guó)專訪:Chameleon原理首發(fā),其它跨多端統(tǒng)一框架都是假的?

    摘要:中國(guó)互聯(lián)網(wǎng)絡(luò)信息中心發(fā)布的中國(guó)互聯(lián)網(wǎng)絡(luò)發(fā)展?fàn)顩r統(tǒng)計(jì)報(bào)告顯示,截至年月,我國(guó)網(wǎng)民規(guī)模達(dá)億人,微信月活億支付寶月活億百度月活億另一方面,中國(guó)手機(jī)占智能手機(jī)整體的比例超過(guò),月活約億。在年末正式發(fā)布了面向未來(lái)的跨端的。 開源中國(guó)專訪:Chameleon原理首發(fā),其它跨多端統(tǒng)一框架都是假的? 原創(chuàng): 嘉賓-張楠 開源中國(guó) 以往我們說(shuō)某一功能跨多端,往往是指在諸如 PC、移動(dòng)等不同類型的設(shè)備之...

    GraphQuery 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<