Swift3.0 - 使用HTML5進(jìn)行iOS開(kāi)發(fā)(將HTML5打包成iOS應(yīng)用)

下面簡(jiǎn)單介紹下如何把HTML5編寫的頁(yè)面編譯成iOS應(yīng)用姑蓝,以及如何讓頁(yè)面與Swift代碼進(jìn)行交互蔬芥。

1,使用UIWebView還是WKWebView來(lái)加載html頁(yè)面

原來(lái)我們一直使用UIWebView來(lái)加載web頁(yè)面。從iOS8起宴霸,蘋果提供了WKWebView用來(lái)代替UIWebView姆坚。

雖然WKWebView不支持緩存和NSURLProtocol 攔截了澳泵,但其加載速度比UIWebView提升差不多一倍的, 內(nèi)存使用上面反而還少了一半。同時(shí)也增加了加載進(jìn)度條屬性兼呵,而不像原來(lái)要使用假的進(jìn)度條兔辅。原生代碼與頁(yè)面js互相調(diào)用也更加方便腊敲。

所有在緩存要求不高的情況下,建議使用WKWebView维苔,用戶體驗(yàn)也會(huì)更好碰辅。

2,使用UIWebView和WKWebView加載html頁(yè)面

我們可以整個(gè)應(yīng)用都使用HTML5來(lái)編寫介时,或者只有某幾個(gè)頁(yè)面使用HTML没宾。

先把HTML5的頁(yè)面導(dǎo)入到項(xiàng)目中來(lái),然后再使用UIWebView或WKWebView加載顯示沸柔。(除了導(dǎo)入到本地工程里循衰,把html頁(yè)面放在服務(wù)器上遠(yuǎn)程加載也是可以的)


(注意:添加文件的時(shí)候有兩種方式:“Create groups”和“Create folder references”。如果你的html頁(yè)面有層次結(jié)構(gòu)勉失,比如css羹蚣,js,圖片都放在各自的子文件夾中乱凿。要選擇后面那個(gè)方式“Create folder references”顽素。如果選第一個(gè),雖然在Xcode組織樹(shù)看來(lái)都是好的徒蟆,但實(shí)際所有加入到項(xiàng)目的文件都會(huì)在mainBundle根路徑下胁出,這樣文件引用就會(huì)出問(wèn)題。)


1)下面是使用UIWebView的樣例:

'''

import UIKit

import WebKit

class ViewController: UIViewController {

override func viewDidLoad() {

super.viewDidLoad()

let path = Bundle.main.path(forResource: "index", ofType: ".html",

inDirectory: "HTML5")

let url = URL(fileURLWithPath:path!)

let request = URLRequest(url:url)

//將瀏覽器視圖全屏(在內(nèi)容區(qū)域全屏,不占用頂端時(shí)間條)

let frame = CGRect(x:0, y:20, width:UIScreen.main.bounds.width,

height:UIScreen.main.bounds.height)

let theWebView = UIWebView(frame:frame)

//禁用頁(yè)面在最頂端時(shí)下拉拖動(dòng)效果

theWebView.scrollView.bounces = false

//加載頁(yè)面

theWebView.loadRequest(request)

self.view.addSubview(theWebView)

}

override func didReceiveMemoryWarning() {

super.didReceiveMemoryWarning()

}

}

'''

(2)下面是使用WKWebView的樣例:

import UIKit

import WebKit

class ViewController: UIViewController {

override func viewDidLoad() {

super.viewDidLoad()

let path = Bundle.main.path(forResource: "index", ofType: ".html",

inDirectory: "HTML5")

let url = URL(fileURLWithPath:path!)

let request = URLRequest(url:url)

//將瀏覽器視圖全屏(在內(nèi)容區(qū)域全屏,不占用頂端時(shí)間條)

let frame = CGRect(x:0, y:20, width:UIScreen.main.bounds.width,

height:UIScreen.main.bounds.height)

let theWebView:WKWebView = WKWebView(frame:frame)

//禁用頁(yè)面在最頂端時(shí)下拉拖動(dòng)效果

theWebView.scrollView.bounces = false

//加載頁(yè)面

theWebView.load(request)

self.view.addSubview(theWebView)

}

override func didReceiveMemoryWarning() {

super.didReceiveMemoryWarning()

}

}

3段审,swift代碼與頁(yè)面js互相調(diào)用(使用WKWebView)

下面通過(guò)一個(gè)簡(jiǎn)單樣例演示js與原生代碼如何進(jìn)行相互調(diào)用以及參數(shù)傳遞全蝶。當(dāng)點(diǎn)擊一個(gè)商品圖片時(shí),會(huì)彈出一個(gè)iOS的消息框寺枉。當(dāng)用戶選擇確定后抑淫,又會(huì)調(diào)用頁(yè)面js方法,把商品添加到購(gòu)物車?yán)锩妗?/p>


--- Swift代碼 ViewController.swift ---

import UIKit

import WebKit?

class ViewController: UIViewController, WKScriptMessageHandler{? ? ? ??

?var theWebView:WKWebView?? ? ? ?

?override func viewDidLoad() {? ? ? ??

super.viewDidLoad()? ? ? ? ? ? ? ?

?let path = Bundle.main.path(forResource: "index", ofType: ".html", ?inDirectory: "HTML5")? ? ? ??

let url = URL(fileURLWithPath:path!)? ? ? ??

let request = URLRequest(url:url)? ? ? ? ? ? ? ??

?//創(chuàng)建供js調(diào)用的接口? ? ? ??

let theConfiguration = WKWebViewConfiguration()? ? ? ??

theConfiguration.userContentController.add(self, name: "interOp")? ? ? ? ? ? ? ??

//將瀏覽器視圖全屏(在內(nèi)容區(qū)域全屏,不占用頂端時(shí)間條)? ? ? ?

?let frame = CGRect(x:0, y:20, width:UIScreen.main.bounds.width, height:UIScreen.main.bounds.height)? ? ? ??

theWebView = WKWebView(frame:frame, configuration: theConfiguration)? ? ? ??

//禁用頁(yè)面在最頂端時(shí)下拉拖動(dòng)效果? ? ? ??

theWebView!.scrollView.bounces = false? ? ? ?

?//加載頁(yè)面? ? ? ??

theWebView!.load(request)? ? ? ??

self.view.addSubview(theWebView!)? ??

}? ? ? ??

?//響應(yīng)處理js那邊的調(diào)用? ?

?func userContentController(_ userContentController:WKUserContentController, didReceive message: WKScriptMessage) {? ? ? ??

print(message.body)? ? ? ??

let sentData = message.body as! Dictionary

//判斷是確認(rèn)添加購(gòu)物車操作

if(sentData["method"] == "addToCarCheck"){

//獲取商品名稱

let itemName = sentData["name"]!

let alertController = UIAlertController(title: "系統(tǒng)提示",

message: "確定把\(itemName)添加到購(gòu)物車嗎姥闪?",

preferredStyle: .alert)

let cancelAction = UIAlertAction(title: "取消", style: .cancel, handler: nil)

let okAction = UIAlertAction(title: "確定", style: .default, handler: {

action in

print("點(diǎn)擊了確定")

//調(diào)用頁(yè)面里加入購(gòu)物車js方法

self.theWebView!.evaluateJavaScript("addToCar('\(itemName)')",

completionHandler: nil)

})

alertController.addAction(cancelAction)

alertController.addAction(okAction)

self.present(alertController, animated: true, completion: nil)

}

}

override func didReceiveMemoryWarning() {

super.didReceiveMemoryWarning()

}

}

--- html頁(yè)面 index.html(這里只展示主要js代碼始苇,還用到了jQuery) ---

$(function() {

//點(diǎn)擊商品添加到購(gòu)物車

$(".goodsItem").click(function() {

var itemName = $(this).children("img")[0].alt;

var message = {"method":"addToCarCheck","name":itemName};

window.webkit.messageHandlers.interOp.postMessage(message);

});

});

//添加到購(gòu)物車

function addToCar(itemName){

//這里只是簡(jiǎn)單的給數(shù)量+1,用來(lái)演示

var num = parseInt($("#cartNums").text());

$("#cartNums").text(num+1);

}

原文出自:www.hangge.com? 轉(zhuǎn)載請(qǐng)保留原文鏈接:http://www.hangge.com/blog/cache/detail_876.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市筐喳,隨后出現(xiàn)的幾起案子催式,更是在濱河造成了極大的恐慌,老刑警劉巖避归,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荣月,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡梳毙,警方通過(guò)查閱死者的電腦和手機(jī)哺窄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人萌业,你說(shuō)我怎么就攤上這事蔑担。” “怎么了咽白?”我有些...
    開(kāi)封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)鸟缕。 經(jīng)常有香客問(wèn)我晶框,道長(zhǎng),這世上最難降的妖魔是什么懂从? 我笑而不...
    開(kāi)封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任授段,我火速辦了婚禮,結(jié)果婚禮上番甩,老公的妹妹穿的比我還像新娘侵贵。我一直安慰自己,他們只是感情好缘薛,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布窍育。 她就那樣靜靜地躺著,像睡著了一般宴胧。 火紅的嫁衣襯著肌膚如雪漱抓。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天恕齐,我揣著相機(jī)與錄音乞娄,去河邊找鬼。 笑死显歧,一個(gè)胖子當(dāng)著我的面吹牛仪或,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播士骤,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼范删,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了敦间?” 一聲冷哼從身側(cè)響起瓶逃,我...
    開(kāi)封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎廓块,沒(méi)想到半個(gè)月后厢绝,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡带猴,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年昔汉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡靶病,死狀恐怖会通,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情娄周,我是刑警寧澤涕侈,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站煤辨,受9級(jí)特大地震影響裳涛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜众辨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一端三、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧鹃彻,春花似錦郊闯、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至谨履,卻和暖如春然痊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背屉符。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工剧浸, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人矗钟。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓唆香,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親吨艇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子躬它,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容