欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

七行JSON代碼把你的網(wǎng)站變成移動應用過程詳解

 更新時間:2019年07月09日 11:28:02   作者:ToEnd  
這篇文章主要介紹了七行JSON代碼把你的網(wǎng)站變成移動應用過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值

如果我告訴你,只需要 下述 7 行橙色的 JSON 代碼 就可以將一個網(wǎng)站變成移動應用,你相信嗎?

完全不需要使用某種框架 API 重寫網(wǎng)站,就可以獲得與移動應用相同的行為。如果你已經(jīng)有一個現(xiàn)成的網(wǎng)站,只需要簡單地引用 URL 就可以將其“打包”為原生應用。

而如果在此基礎上,只需要略微調(diào)整 JSON 代碼內(nèi)容,就可以直接訪問所有原生 API、原生 UI 組件以及原生視圖切換(View Transition)。最簡化的范例效果如下圖所示:

從中可以看出,我嵌入了一個 Web 頁面,但界面上其余布局均為原生 UI 組件,例如 導航條 以及 底部的標簽欄。而我們并不需要使用任何 API 重寫網(wǎng)站,就可以自動獲得原生的切換效果。

在介紹具體做法前你可能會問:“看著挺酷,但除了在原生應用框架內(nèi)展示 Web 頁面之外,這種技術(shù)還有什么意義?”問得好!這也是本文要講的重點。

我們只需要創(chuàng)建一個無縫的 Web 視圖與應用間雙向通信,借此,父應用就可以觸發(fā) Web 視圖內(nèi)的任何 JavaScript 函數(shù),隨后 Web 視圖即可從外部調(diào)用原生 API。例如:

請注意,這個視圖包含:原生導航條,以及內(nèi)置的切換功能一個 Web 視圖,其中嵌入了一個可以生成二維碼的 Web 應用在底部包含一個原生的文字輸入組件上述所有這一切只需要略微調(diào)整 JSON 代碼的屬性即可實現(xiàn)。

最后請注意,隨著在文字輸入?yún)^(qū)輸入不同內(nèi)容,二維碼也會產(chǎn)生相應變化。輸入的文字可觸發(fā)二維碼生成器 Web 應用內(nèi)部的 JavaScript 函數(shù)重新生成二維碼圖像。

目前還沒有任何一個開發(fā)框架曾試圖從根本上解決“Web 視圖與原生應用無縫集成”的問題,因為這些框架都專注于完全原生,或完全 HTML5 的做法。無論什么時候當我們聽到有人討論移動應用的未來時,很可能會聽到類似“到底是 HTML5 還是原生方法會最終勝出呢?”這樣的說法。似乎沒人覺得native和html可以共存,而且二者的協(xié)同和最終實現(xiàn)似乎也并不容易。

本文我將要介紹:為何 Web 引擎與原生組件的融合通常是一種更好的做法。為何 HTML 與原生的無縫集成那么難,具體又該如何實現(xiàn)。更重要的是,該如何使用這樣的技術(shù)快速構(gòu)建自己的應用。

為何要在原生應用中使用 HTML?

在進一步介紹前,首先一起看看這樣做是好是壞,以及什么時候適合使用這種方法。這種做法的一些潛在用例如下:

1. 使用 Web 原生功能

應用中的部分內(nèi)容使用 Web 引擎來實現(xiàn)也許是一種更適合的做法。例如 WebSocket 是一種原生的 Web 功能,主要面向 Web 環(huán)境而設計。這種情況下就更適合使用內(nèi)建的 Web 引擎(iOS 的 WKWebView 以及 Android 的 WebView),而非安裝某些只能“模擬”WebSocket 的第三方庫。無需額外安裝任何代碼,使用免費工具即可實現(xiàn)目標,這樣豈不是更好。同時這也催生了下一個原因。

2. 避免二進制文件體積過大

有些功能也許需要借助龐大的第三方庫,而你可能希望能快速用上這樣的功能。例如,為了以原生方式包含二維碼圖像生成器,可能需要安裝某些第三方庫,這會導致二進制文件體積增大。但如果使用 Web 視圖引擎并通過一個簡單的調(diào)用 JavaScript 庫,就可以免費實現(xiàn)這一切,并且避免了使用第三方原生庫。

3. 缺乏可靠的移動庫

對于一些前沿技術(shù),可能暫時并不具備穩(wěn)定可靠的移動端實現(xiàn)。好在大部分此類技術(shù)都具備 Web 實現(xiàn),因此最高效的集成方法就是使用 JavaScript 庫。

4. 構(gòu)建部分原生,部分基于 Web 的應用

很多新手開發(fā)者想要將自己的網(wǎng)站移植為移動應用,但在發(fā)現(xiàn)自己現(xiàn)有網(wǎng)站的部分功能過于復雜,無法面向每種移動平臺快速重寫時,往往會感到沮喪或受挫。例如你可能有一個非常復雜的 Web 頁面無法快速轉(zhuǎn)換為移動應用,但網(wǎng)站的其他內(nèi)容可以很容易地轉(zhuǎn)換。面對這種情況,如果通過某種方法將應用的大部分內(nèi)容以原生方式構(gòu)建,對于特別復雜的頁面直接將其以 HTML 的形式無縫集成到應用中,是不是很棒啊。

這是如何實現(xiàn)的?

A. Jasonette

Jasonette 是一種基于標記語言,構(gòu)建跨平臺原生應用的開源方法。該技術(shù)看似 Web 瀏覽器,但并不會將 HTML 標記語言解釋為 Web 頁面,而是會將 JSON 標記解釋為 iOS 和 Android 上的原生應用。正如所有 Web 瀏覽器都有完全相同的代碼,但只要按需解釋不同類型的 HTML 標記,即可為用戶提供所有不同類型的 Web 應用,所有 Jasonette 應用也有著完全相同的庫,可按需解釋不同類型的 JSON 標記并創(chuàng)建出你的應用。開發(fā)者完全無需觸及代碼本身,只需要編寫標記,將代碼實時“翻譯”為原生應用,即可開發(fā)出自己的應用來。雖然 Jasonette 的核心作用在于構(gòu)建原生應用,但本文的重點在于介紹如何將 HTML 集成到核心原生引擎中,接下來就一起了解一下吧。

B. Jasonette Web 容器

原生應用很棒,但有時候我們依然需要使用 Web 功能。但 Web 視圖與原生應用的集成是個麻煩的過程。

無縫的集成要求:

Web 視圖應作為原生布局的一部分進行集成:Web 視圖應作為原生布局的一部分納入應用中,并且操作方式應與其他任何原生 UI 組件保持一致。否則會讓用戶感覺很笨拙,并且感覺上就像自己實際上是在訪問網(wǎng)站那樣。

父應用可以控制子 Web 容器:父應用應能隨意控制子 Web 視圖。

子 Web 容器可觸發(fā)父應用的原生事件:子應用應該能觸發(fā)父應用的事件以運行原生 API。這是一個非常繁重的工作,因此先從第一個環(huán)節(jié)著手介紹:直接將 Web 容器嵌入原生布局—并將其作為第 1 版發(fā)布:JSON Web 容器,JSON 中的 HTML 將變?yōu)樵鷳媒M件。僅這一點就已經(jīng)很實用了,但由于無法交互,依然存在一定的局限。父應用無法控制子 Web 容器,子容器無法向父應用發(fā)送任何事件通知,這 導致 Web 容器與外界完全隔離。

C. Jasonette Web 容器 2.0:使其可交互

發(fā)布第 1 版之后,我們開始處理第二個問題:為 Web 容器添加交互能力。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • js left,right,mid函數(shù)

    js left,right,mid函數(shù)

    在JAVASCRIPT中LEFT,RIGHT,MID函數(shù)的等價函數(shù),非常適合經(jīng)常用寫asp的朋友
    2008-06-06
  • JavaScript函數(shù)調(diào)用經(jīng)典實例代碼

    JavaScript函數(shù)調(diào)用經(jīng)典實例代碼

    JavaScript提供了4種函數(shù)調(diào)用,一般形式的函數(shù)調(diào)用、作為對象的方法調(diào)用、使用 call 和 apply 動態(tài)調(diào)用、使用 new 間接調(diào)用,下面這篇文章主要給大家介紹了關于JavaScript函數(shù)調(diào)用的相關資料,需要的朋友可以參考下
    2021-12-12
  • JS 動態(tài)加載腳本的4種方法

    JS 動態(tài)加載腳本的4種方法

    有時候我們需要動態(tài)的加入適合的js,因為有時候不需要將所有的js都加載進來,以來提高效率,但這種方法比較適合單個js文件比較大的情況
    2009-05-05
  • JavaScript圖片懶加載的優(yōu)化方法詳解

    JavaScript圖片懶加載的優(yōu)化方法詳解

    這篇文章主要為大家詳細介紹了JavaScript圖片懶加載的優(yōu)化方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • JS獲取input file絕對路徑的方法(推薦)

    JS獲取input file絕對路徑的方法(推薦)

    下面小編就為大家?guī)硪黄狫S獲取input file絕對路徑的方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • 詳解webpack 入門與解析

    詳解webpack 入門與解析

    這篇文章主要介紹了詳解webpack 入門與解析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • 利用js判斷數(shù)據(jù)是否是數(shù)組或字符串的常見方法

    利用js判斷數(shù)據(jù)是否是數(shù)組或字符串的常見方法

    這篇文章主要給大家介紹了關于利用js判斷數(shù)據(jù)是否是數(shù)組或字符串的常見方法,其實有很多方法可以判斷數(shù)據(jù)是否是數(shù)組或字符串,需要的朋友可以參考下
    2023-07-07
  • JavaScript簡單獲取頁面圖片原始尺寸的方法

    JavaScript簡單獲取頁面圖片原始尺寸的方法

    這篇文章主要介紹了JavaScript簡單獲取頁面圖片原始尺寸的方法,可通過Image()對象直接獲取圖片的原始寬高,簡單實用,需要的朋友可以參考下
    2016-06-06
  • 完美解決手機網(wǎng)頁中輸入框被輸入法遮擋的問題

    完美解決手機網(wǎng)頁中輸入框被輸入法遮擋的問題

    下面小編就為大家分享一篇完美解決手機網(wǎng)頁中輸入框被輸入法遮擋的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • Bootstrap頁面標題Page Header的實現(xiàn)方法

    Bootstrap頁面標題Page Header的實現(xiàn)方法

    這篇文章主要為大家詳細介紹了Bootstrap頁面標題Page Header的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評論