亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

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

2024-05-06 16:53:12
字體:
來源:轉載
供稿:網友

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

JSON代碼,移動應用

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

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

JSON代碼,移動應用

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

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

我們只需要創建一個無縫的 Web 視圖與應用間雙向通信,借此,父應用就可以觸發 Web 視圖內的任何 JavaScript 函數,隨后 Web 視圖即可從外部調用原生 API。例如:

JSON代碼,移動應用

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

最后請注意,隨著在文字輸入區輸入不同內容,二維碼也會產生相應變化。輸入的文字可觸發二維碼生成器 Web 應用內部的 JavaScript 函數重新生成二維碼圖像。

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

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

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

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

1. 使用 Web 原生功能

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

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

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

3. 缺乏可靠的移動庫

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

4. 構建部分原生,部分基于 Web 的應用

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

這是如何實現的?

A. Jasonette

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

B. Jasonette Web 容器

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

無縫的集成要求:

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

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

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

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人激情在线| 中文字幕日韩av综合精品| 国产精品黄色影片导航在线观看| 俺去了亚洲欧美日韩| 黑人巨大精品欧美一区免费视频| 国产精品小说在线| 91国自产精品中文字幕亚洲| 中日韩美女免费视频网站在线观看| 91精品在线影院| 日韩欧美中文免费| 97精品视频在线| 国产精品高潮粉嫩av| 日韩精品欧美国产精品忘忧草| 日韩国产激情在线| 伊人久久五月天| 成人激情电影一区二区| 日本三级韩国三级久久| 岛国av在线不卡| 国产精品福利久久久| 神马久久桃色视频| 国产精品∨欧美精品v日韩精品| 一本一道久久a久久精品逆3p| 久久97精品久久久久久久不卡| 欧美高清视频在线播放| 在线丨暗呦小u女国产精品| 91av在线免费观看| 韩曰欧美视频免费观看| 伊人av综合网| 亚洲精品免费av| 日韩精品在线观| 97香蕉超级碰碰久久免费的优势| 国产精品久久久久久av福利| 成人激情电影一区二区| 国产精品久久久久久av福利| 欧美在线视频免费| 精品毛片三在线观看| 视频在线观看99| 91亚洲一区精品| 日韩在线视频二区| 国产精品jvid在线观看蜜臀| 国内精品一区二区三区| 热re91久久精品国99热蜜臀| 久久91亚洲人成电影网站| 中日韩美女免费视频网址在线观看| 77777亚洲午夜久久多人| 精品国产欧美一区二区三区成人| 欧美视频裸体精品| 欧美日韩精品二区| 91香蕉嫩草神马影院在线观看| 亚洲女同精品视频| 最好看的2019的中文字幕视频| 91午夜理伦私人影院| 欧美国产日韩在线| 日本免费久久高清视频| 精品国产一区二区三区久久狼黑人| 成人乱人伦精品视频在线观看| 91av免费观看91av精品在线| 色噜噜狠狠狠综合曰曰曰88av| 国产不卡视频在线| 91免费高清视频| 色综合天天狠天天透天天伊人| 激情久久av一区av二区av三区| 国产午夜精品美女视频明星a级| 成人性生交大片免费观看嘿嘿视频| www.欧美精品| 久久久久亚洲精品| 亚洲视频自拍偷拍| 欧美日韩亚洲网| 欧美老妇交乱视频| 国产在线观看精品| 一区二区三区美女xx视频| 日韩中文娱乐网| 国产成人一区二区在线| 日韩天堂在线视频| 亚洲精品美女久久久久| 久久视频在线直播| 国产成人精品电影久久久| 久久久噜噜噜久噜久久| 欧美性xxxxx极品娇小| 91av在线免费观看视频| 在线免费观看羞羞视频一区二区| 国产成人精品网站| 91超碰中文字幕久久精品| 91精品国产色综合久久不卡98口| 国产日韩欧美视频在线| 国产精品福利网| 亚洲国产精品久久久久| 久久久久久网站| 在线a欧美视频| 久久免费视频这里只有精品| 久久精品国产2020观看福利| 日韩精品免费一线在线观看| 日韩女优人人人人射在线视频| 亚洲最新在线视频| 欧美精品制服第一页| 亚洲国产精品久久| 亚洲在线一区二区| 日韩欧美国产中文字幕| 国产黑人绿帽在线第一区| 国产91热爆ts人妖在线| 4438全国成人免费| 97碰碰碰免费色视频| 91av在线视频观看| 在线视频精品一| 亚洲国产精品女人久久久| 91免费欧美精品| 欧美高清视频免费观看| 欧美精品在线视频观看| 久久亚洲精品小早川怜子66| 国产精品免费看久久久香蕉| 欧美日本亚洲视频| 日韩在线视频网站| 国产69精品久久久久久| 国产热re99久久6国产精品| 少妇av一区二区三区| 亚洲男人的天堂在线播放| 日韩中文在线不卡| 日韩国产高清视频在线| 九九热最新视频//这里只有精品| 日韩中文理论片| 欧美一级淫片videoshd| 亚洲少妇激情视频| 96精品视频在线| 久久精品91久久香蕉加勒比| 亚洲国产高清高潮精品美女| 欧美黑人巨大精品一区二区| 一区二区三区回区在观看免费视频| 久久视频在线播放| 日韩美女免费观看| 国内精品久久久久影院优| 国产精品久久久久久久久久三级| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧美国产va在线影院| 国产精品久久久久久久7电影| 欧美诱惑福利视频| 91国产高清在线| 性欧美视频videos6一9| 欧美丝袜美女中出在线| 成人做爽爽免费视频| 国产成人福利网站| 92看片淫黄大片看国产片| 九九热精品视频| 日韩欧美在线视频免费观看| 97久久精品人搡人人玩| 91高清视频免费观看| 亚洲精品综合久久中文字幕| 久热精品视频在线观看| 免费97视频在线精品国自产拍| 亚洲国产日韩欧美在线99| 成人日韩av在线| 久久在精品线影院精品国产| 日本高清不卡在线| 国产一区二区三区三区在线观看| 中文字幕一精品亚洲无线一区| 亚洲成人久久一区| 亚洲aⅴ男人的天堂在线观看| 中文字幕日韩精品在线| 亚洲第一页中文字幕| 一本色道久久88亚洲综合88| xxx一区二区| 欧美午夜激情小视频| 日本乱人伦a精品| 在线观看国产精品日韩av| 色悠悠久久88|