gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

html5混合開發是什么

html5混合開發是指同時采用原生(程序語言)與H5(Web語言)技術來開發應用;混合開發是一種取長補短的開發模式,原生代碼部分利用插件或者其它框架為H5提供容器,程序主要的業務實現、界面展示都是利用與H5相關的技術進行實現的。

html5混合開發是什么

本教程操作環境:windows7系統、HTML5版、Dell G3電腦。

目前市場上主流的APP分為三種:原生APP、Web APP(即HTML5)和混合APP三種,相對應的定 制開發就是原生開發、H5開發和混合開發。

混合開發是什么?

混合開發,是指在開發一款App產品的時候,為了提高效率、節省成本而利用原生與H5的開發技術的混合應用。通俗點來說,這就是網頁的模式,同時采用網頁語言和程序語言進行開發,通常由“H5云網站+APP應用客戶端”兩部份構成。

混合開發是一種取長補短的開發模式,原生代碼部分利用插件或者其它框架為H5提供容器,程序主要的業務實現、界面展示都是利用與H5相關的技術進行實現的。很多APP都是利用混合開發模式而成的。

優點:

1、開發效率高,節約時間。同一套代碼Android和IOS基本上都可使用;

2、更新和部署比較方便,每次升級版本只需要在服務器端升級即可,不再需要上傳到App Store進行審核;

3、代碼維護方便、版本更新快,節省產品成本;

4、比web版實現功能多;

5、可離線運行。

缺點:

1、功能/界面無法自定:所有內容都是固定的,不能換界面或增加功能;

2、加載緩慢/網絡要求高:混合APP數據需要全部從服務器調取,每個頁面都需要重新下載,因此打開速度慢,網絡占用高,緩沖時間長,容易讓用戶反感;

3、安全性比較低:代碼都是以前的老代碼,不能很好地兼容最新手機系統,且安全性較低,網絡發展這么快,病毒這么多,如果不實時更新,定期檢查,容易產生漏洞,造成直接經濟損失;

4、既懂原生開發又懂H5開發的高端人才難找。

混合APP原理

混合APP通常由前端負責大部分界面開發和業務邏輯,原生負責封裝原生功能供前端調用,二者以 WebView 作為媒介建立通信,從而既擁有 Web 開發的速度優勢,又能擁有強大的原生能力。

從一個前端開發者的角度來看,混合應用可以簡單地理解為讓前端頁面跑在一個特殊的瀏覽器環境里,這個環境除了常規 Web API之外,還額外提供了很多可以直接調用手機原生能力的 API。

從一個原生開發者的角度來看,混合應用其實就是一個原生開發的 App 外殼,這個外殼將原生功能封裝成很多 API 并注入到 WebView 里,然后將前端頁面打包進 App,App 啟動時用 WebView 加載前端頁面,剩下的就全交給前端了。

web網頁和ios,android進行交互(原理)

web網頁和ios,android進行交互(原理)

  • web網頁調用ios和android

  • web頁面發送一個假的請求, ios,android攔截請求,解析是真請求還是假請求

    • 真請求放行

    • 假請求攔截,解析出真實的功能需求字段,

    • 通過發布訂閱,傳遞給相應文件,做出相應的操作

發送一個假請求,讓原生開發攔截(該加請求的url路勁需要和ios,android設置的保持一致)
ios攔截請求

// 繼承類MyURLProtocol,子類NSURLProtocol // MyURLProtocol.h文件 #import <Foundation/Foundation.h>  NS_ASSUME_NONNULL_BEGIN @interface MyURLProtocol: NSURLProtocol    @end
// MyURLProtocol.m文件 #import "MyURLProtocol.h" @implementation MyURLProtocol  // 手機app是否可以加載請求 + (BOOL)canInitWithRequest:(NSURLRequest *)request{          //攔截到請求后,獲取請求的字符串     NSString *path = request.URL.absoluteString;          // 判斷字符串是否以協商好的虛假協議開頭(如emma://開頭)     if([path hasPrefix:@"emma://"]){         // 這是個假請求         // 獲取該請求真實目的         NSString *action = [path substringFromIndex:7];                  // 該文件不能調用一些原生功能,需要裝有webview的視圖文件才行,所以要將該請求字段傳給視圖文件         // 文件間不能通信,用發布訂閱(ios自帶一個發布訂閱)         if([action isEqualToString:@"captureImage"]){             // 發送消息,拍照             [[NSNotificationCenter defaultCenter] postNotificationName:@"captureImage" object:nil userInfo:nil];         }                  // 攔截掉該請求         return NO;     } else {         // 真請求         // 允許該請求通過         return YES;     } }      @end
// 裝有webview的頁面(文件) #import "MyURLProtocol.h"  // 注冊MyURLProtocol,可以實現攔截 [NSURLProtocol registerClass:[MyURLProtocol class]];  // 訂閱消息,拍照的消息 [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleCaptureImage) name:@"captureImage" object:nil];  // 訂閱拍照消息的處理函數 -(void)handleCaptureImage{     // 拍照的操作 }

html發送假請求

<!-- // HTML文件發送假請求 --> <a href="emma://captureImage">拍照</a> <a href="emma://openweChart">打開微信</a> <a href="emma://scan">掃一掃</a>
// js文件發送假請求 window.location.href = 'emma://captureImage';

ios,android傳值給web網頁

先在網頁上準備一個獲得結果的回調函數

當原生需要傳值給網頁時,向打開網頁的窗口動態插入js代碼,這段js代碼就是調用回調函數的代碼

web代碼

import React, { useState } from 'react' function WebView() {  const [image, setimage] = useState('');    const btnAction = () => {      // 發送一個假的請求,觸發原生       window.location.href = 'emma://captureImage';              // 在window設置了一個回調方法(模塊化開發,ios只能找到window全局作用域,所以只能掛在window上)       window.onCaptureImageCallback = (value) => {           setimage(value)       }  }    return (  	<div>      	<button onClick={btnAction}>拍照</button>          <img src={image} />      </div>  ) }

ios代碼

// webview的文件 // 需要將webview提升成全局變量(掛載webview的函數和處理發布訂閱事件的函數是兩個作用域) @property (strong, nonatomic) WKWebView *webview;  // 事件處理函數中 // 向窗口注入js代碼 NSString *jsMethod = [NSString stringWithFormat:@"window.onCaptureImageCallback('%@')", @"需要傳給網頁的值"]; [self.webview evaluateJavaScript:jsMethod completionHandler:nil];

擴展知識:原生開發和Web APP (HTML5)開發的優缺點

原生開發

原生開發(Native App開發),是在Android、IOS等移動平臺上利用官方提供的開發語言、開發類庫、開發工具進行App開發。比如Android是利用Java、Eclipse、Android studio;IOS是利用Objective-C 和Xcode進行開發。

通俗點來講,原生開發就像蓋房子一樣,先打地基然后澆地梁、房屋結構、一磚一瓦、鋼筋水泥、電路走向等,都是經過精心的設計。原生APP也一樣:通過代碼從每個頁面、每個功能、每個效果、每個邏輯、每個步驟全部用代碼寫出來,一層層,一段段全用代碼寫出來。

優點:

1、可訪問手機所有功能(如GPS、攝像頭等)、可實現功能最齊全;

2、運行速度快、性能高,絕佳的用戶體驗;

3、支持大量圖形和動畫,不卡頓,反應快;

4、兼容性高,每個代碼都經過程序員精心設計,一般不會出現閃退的情況,還能防止病毒和漏洞的出現;

5、比較快捷地使用設備端提供的接口,處理速度上有優勢。

缺點:

1、開發時間長,快則3個月左右完成,慢則五個月左右;

2、制作費用高昂,成本較高;

3、可移植性比較差,一款原生的App,Android和IOS都要各自開發,同樣的邏輯、界面要寫兩套;

4、內容限制(App Store限制);

5、必須等下載完畢用戶才可以打開,獲得新版本時需重新下載應用更新。

Web APP (HTML5)開發

HTML5應用開發,是利用Web技術進行的App開發,可以在手機端瀏覽器里面打開的網站就稱之為webapp。Web技術本身需要瀏覽器的支持才能進行展示和用戶交互,因此主要用到的技術是HTML、CSS、Javascript以及jQuery、Vue、React等JS框架。

優點:

1、支持設備范圍廣,可以跨平臺,編寫的代碼可以同時在Android、IOS、Windows上運行;

2、開發成本低、周期短;

3、無內容限制;

4、適合展示有大段文字(如新聞、攻略等),且格式比較豐富(如加粗,字體多樣)的頁面;

5、用戶可以直接使用最新版本(自動更新,不需用戶手動更新)。

缺點:

1、由于Web技術本身的限制,H5移動應用不能直接訪問設備硬件和離線存儲,所以在體驗和性能上有很大的局限性;

2、對聯網要求高,離線不能做任何操作;

3、功能有限;

4、APP反應速度慢,頁面切換流暢性較差;

5、圖片和動畫支持性不高;

6、用戶體驗感較差;

7、無法調用手機硬件(攝像頭、麥克風等)。

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
无套内谢丰满少妇中文字幕| 116极品美女午夜一级| 无套内谢丰满少妇中文字幕| 天天综合中文字幕| 欧美激情 国产精品| www.av中文字幕| 手机av在线免费| 免费 成 人 黄 色| 日本精品久久久久中文字幕| 色天使在线观看| 成人中文字幕在线播放| 欧美一级特黄aaa| 欧美成人免费高清视频| 韩国无码av片在线观看网站| 在线观看免费视频污| 久久久一本二本三本| 91极品视频在线观看| 妞干网在线观看视频| 干日本少妇视频| 久久婷婷综合色| 99免费视频观看| 欧美 丝袜 自拍 制服 另类 | 成年女人18级毛片毛片免费| 孩娇小videos精品| 青青草精品视频在线观看| 熟女少妇在线视频播放| 轻点好疼好大好爽视频| 中文字幕黄色大片| 免费一级特黄毛片| 亚洲人精品午夜射精日韩| 国产精品无码免费专区午夜| 国产精品99久久久久久大便| 久久久国产精华液999999 | 一本二本三本亚洲码| 欧美午夜精品理论片| 欧美大片久久久| 激情小视频网站| 欧美日韩第二页| 超碰在线超碰在线| 日韩av片在线看| 一区二区在线播放视频| 高潮一区二区三区| 欧美性视频在线播放| 丰满的少妇愉情hd高清果冻传媒| 成人免费在线网| 国产精品入口免费软件| 性一交一乱一伧国产女士spa| 在线观看av免费观看| 亚洲一区二区在线视频观看| 日本美女高潮视频| 福利视频一区二区三区四区| 色婷婷成人在线| 男人舔女人下面高潮视频| 国产精品www在线观看| 亚洲五月激情网| 日本美女爱爱视频| 成人在线观看黄| 国产精品入口免费软件| 国产精品igao| 91黄色在线看| 超级碰在线观看| 美国av在线播放| 婷婷五月综合缴情在线视频| 欧美成人高潮一二区在线看| 亚洲熟妇av日韩熟妇在线| www.99在线| 麻豆中文字幕在线观看| 一本久道高清无码视频| 97国产精东麻豆人妻电影 | 亚洲色图久久久| 日韩va在线观看| 波多野结衣之无限发射| 色哟哟精品视频| 五月天婷婷影视| 欧美精品卡一卡二| 手机看片福利盒子久久| 777米奇影视第四色| www.偷拍.com| 黄色动漫网站入口| 手机在线视频你懂的| 欧美变态另类刺激| 国产手机视频在线观看| 日本成人黄色网| 日韩人妻精品一区二区三区| 国产美女三级视频| 国产美女无遮挡网站| 三级在线免费观看| 无尽裸体动漫2d在线观看| 黄色三级中文字幕| 亚洲人视频在线| 少妇激情一区二区三区| 玖玖爱视频在线| www.久久av.com| 午夜精品在线免费观看| 国产成人在线免费看| 日本a在线免费观看| 中文字幕无码精品亚洲35| 激情小视频网站| 青青在线免费观看| 91精品国产91久久久久麻豆 主演| 国内自拍视频网| 久久久久久久久久久久91| 国产免费视频传媒| 久久精品免费网站| 国产又大又长又粗又黄| 国产精品久久久久7777| 看全色黄大色大片| 久操网在线观看| 国产男女免费视频| 久久婷婷中文字幕| 亚洲啊啊啊啊啊| 日本女优爱爱视频| 国产大尺度在线观看| 日韩一级性生活片| 午夜激情福利在线| 91精品国产91久久久久麻豆 主演| 自拍日韩亚洲一区在线| 超碰免费在线公开| 国产三级三级三级看三级| 一级特黄妇女高潮| 中文字幕 91| 男女激情无遮挡| 日韩精品综合在线| 色噜噜狠狠永久免费| 成人在线免费观看av| 182午夜视频| 91看片在线免费观看| 欧美性久久久久| 欧美无砖专区免费| 欧洲精品视频在线| 在线免费观看av网| 中文字幕一区二区在线观看视频 | 特级西西人体www高清大胆| 欧美自拍小视频| 国产精品-区区久久久狼| 人妻少妇精品久久| 亚洲自偷自拍熟女另类| 老司机午夜av| 日本香蕉视频在线观看| 18禁男女爽爽爽午夜网站免费| 日日橹狠狠爱欧美超碰| 国产精品嫩草影院8vv8| 日本精品福利视频| 四虎永久在线精品无码视频| 超碰在线免费观看97| www.国产区| 国产精品免费入口| 操bbb操bbb| 欧美一级视频在线| 国产自偷自偷免费一区 | 免费看av软件| 99九九精品视频| 一二三四中文字幕| 国产av天堂无码一区二区三区| 妺妺窝人体色www看人体| 人人爽人人爽av| 欧美 另类 交| 秋霞在线一区二区| 视色,视色影院,视色影库,视色网| 国产亚洲欧美在线视频| 成人毛片视频网站| 久艹视频在线免费观看| 一本久道高清无码视频| 北条麻妃在线观看| 欧美午夜aaaaaa免费视频| 91极品尤物在线播放国产| 99九九精品视频| 国产高清不卡无码视频| 久久网站免费视频| 妞干网在线免费视频| 国产96在线 | 亚洲| 浮妇高潮喷白浆视频| 四季av一区二区三区| 欧美一级特黄aaa| 日韩中文字幕亚洲精品欧美| 丰满女人性猛交| 精品无码一区二区三区在线| 大片在线观看网站免费收看| 亚洲 欧洲 日韩| 国产又粗又爽又黄的视频| 日韩精品一区二区三区四| 国产91在线亚洲| 国产综合中文字幕| 日本熟妇人妻中出| 一起操在线视频| 欧洲精品一区二区三区久久| 男女视频网站在线观看| 久久9精品区-无套内射无码| 一本久道综合色婷婷五月| 成 人 黄 色 小说网站 s色| 天天爱天天做天天操| 国产资源在线视频| 男生操女生视频在线观看| 国产女主播自拍| 99视频在线视频| 欧洲精品一区二区三区久久| 色乱码一区二区三区在线| 999一区二区三区| 午夜久久久久久久久久久| www黄色在线|