小程序與普通網頁開發(fā)的區(qū)別
?小程序的主要開發(fā)語言是 JavaScript ,小程序的開發(fā)同普通的網頁開發(fā)相比有很大的相似性。對于前端開發(fā)者而言,從網頁開發(fā)遷移到小程序的開發(fā)成本并不高,但是二者還是有些許區(qū)別的。
?網頁開發(fā)渲染線程和腳本線程是互斥的,這也是為什么長時間的腳本運行可能會導致頁面失去響應,而在小程序中,二者是分開的,分別運行在不同的線程中。網頁開發(fā)者可以使用到各種瀏覽器暴露出來的 DOM API,進行 DOM 選中和操作。而如上文所述,小程序的邏輯層和渲染層是分開的,邏輯層運行在 JSCore 中,并沒有一個完整瀏覽器對象,因而缺少相關的DOM API和BOM API。這一區(qū)別導致了前端開發(fā)非常熟悉的一些庫,例如 jQuery、 Zepto 等,在小程序中是無法運行的。同時 JSCore 的環(huán)境同 NodeJS 環(huán)境也是不盡相同,所以一些 NPM 的包在小程序中也是無法運行的。
?網頁開發(fā)者需要面對的環(huán)境是各式各樣的瀏覽器,PC 端需要面對 IE、Chrome、QQ瀏覽器等,在移動端需要面對Safari、Chrome以及 iOS、Android 系統(tǒng)中的各式 WebView 。而小程序開發(fā)過程中需要面對的是兩大操作系統(tǒng) iOS 和 Android 的微信客戶端,以及用于輔助開發(fā)的小程序開發(fā)者工具,小程序中三大運行環(huán)境也是有所區(qū)別的,如表1-1所示。
表1-1 小程序的運行環(huán)境
運行環(huán)境 |
邏輯層 |
渲染層 |
iOS |
JavaScriptCore |
WKWebView |
安卓 |
V8 |
chromium定制內核 |
小程序開發(fā)者工具 |
NWJS |
Chrome WebView |
?網頁開發(fā)者在開發(fā)網頁的時候,只需要使用到瀏覽器,并且搭配上一些輔助工具或者編輯器即可。小程序的開發(fā)則有所不同,需要經過申請小程序帳號、安裝小程序開發(fā)者工具、配置項目等等過程方可完成。
體驗小程序