前幾天,騰訊開源在公眾號上推送了一篇《微信小程序多端框架 kbone 開源》的文章,鑒于小程序的火熱,今天就和大家分享一下這個由官方出品的小程序框架。這個框架在去年就已經(jīng)發(fā)布,微信小程序開發(fā)過程中,許多開發(fā)者會遇到小程序 與 Web 端一起的需求,但是微信小程序的底層模型和 Web 端不同,我們想直接把 Web 端的代碼挪到小程序環(huán)境內(nèi)執(zhí)行是不可能的。為了解決這個問題,微信小程序推出了同構(gòu)解決方案 kbone。kbone方案設(shè)計有如下幾個前提:
-
為了更好的復(fù)用組件,盡可能完整的支持 Web 端的特性
-
在小程序端的渲染結(jié)果要盡可能接近 Web 端 h5 頁面
-
大部分流行的前端框架都能夠在 kbone 上運行,比如 Vue、React、Preact 等。
-
支持更為完整的前端框架特性,因為 kbone 不會對框架底層進(jìn)行刪改(比如 Vue 中的 v-html 指令、Vue-router 插件)。
-
提供了常用的 dom/bom 接口,讓用戶代碼無需做太大改動便可從 Web 端遷移到小程序端。
-
在小程序端運行時,仍然可以使用小程序本身的特性(比如像 live-player 內(nèi)置組件、分包功能)。
-
提供了一些 Dom 擴(kuò)展接口,讓一些無法完美兼容到小程序端的接口也有替代使用方案(比如 getComputedStyle 接口)。
?
npm install -g kbone-cli
?
使用 kbone-cli 快速開發(fā),對于新項目,可以使用 kbone-cli 來創(chuàng)建項目,首先安裝 kbone-cli:創(chuàng)建項目:?
kbone init my-app
?
進(jìn)入項目,按照 README.md 的指引進(jìn)行開發(fā):?
// 開發(fā)小程序端
npm run mp
// 開發(fā) Web 端
npm run web
// 構(gòu)建 Web 端
npm run build
?
剩余兩種方式是使用模板快速開發(fā)和手動配置開發(fā),感興趣的可以到GitHub上查看。?
?
目前,kbone已經(jīng)在GitHub上已經(jīng)標(biāo)星1.5K,129個Fork。(GitHub地址:https://github.com/Tencent/kbone)?
本文摘自 :https://blog.51cto.com/m