iOS webview懶加載html數(shù)據(jù)

? ? ? ? 本文章只針對iOS初級開發(fā)者见咒,如果大家有更好的意見歡迎在下方留言失晴。

? ? ? ? 不知道大家有沒有遇到這樣的問題,就是后臺返回的數(shù)據(jù)里面有一段html格式的數(shù)據(jù)里面包含文字和眾多的圖片,然后在客戶端通過webView加載這段數(shù)據(jù),但是當(dāng)圖片太多的時候輕則會特別慢重則會導(dǎo)致占用太多內(nèi)存導(dǎo)致手機(jī)內(nèi)存不足退出app描沟,顯然不能滿足公司產(chǎn)品的要求飒泻。

? ? ? ? 為了解決這個問題真是搓破了腦瓜最后還是沒有解決鞭光,無意中看到了一個帖子關(guān)于懶加載html數(shù)據(jù)中的圖片吏廉,但是眾說紛紜好多關(guān)于這種問題的描述,沒有個能參考的帖子惰许,所以今天在這里坐下來寫這個帖子希望能幫助和我一樣遇到此類問題的程序員席覆。


關(guān)于解決這個問題需要準(zhǔn)備一下一些東西:
1. jquery-3.1.1.js? -- 官網(wǎng)下載地址( jquery庫官方下載?)

2. jquery.lazyload.js? -- 官網(wǎng)下載地址( ?jquery.lazyload官方下載 )

3. 基本掌握js語法(當(dāng)然不會也沒關(guān)系)


廢話不多說了,接下來上代碼?

//添加到約束的html字符串(為了簡單約束已去掉)汹买,content為返回的html格式字符串

NSString*str = [NSStringstringWithFormat:@"%@"content];

//將html字符串中的src替換為data-original否則jquery不會實(shí)現(xiàn)懶加載******

NSString*htmlReplaceString = [strstringByReplacingOccurrencesOfString:@"src"withString:@"data-original"];

//獲取temp文件的路徑(temp文件為實(shí)現(xiàn)懶加載的js核心代碼)

NSString*tempPath = [[NSBundlemainBundle]pathForResource:@"temp"ofType:@"html"];

//加載temp內(nèi)容為字符串

NSString*tempHtml = [NSStringstringWithContentsOfFile:tempPathencoding:NSUTF8StringEncodingerror:nil];

//替換temp內(nèi)的占位符{{Content_holder}}為需要加載的HTML代碼

tempHtml = [tempHtmlstringByReplacingOccurrencesOfString:@"{{Content_holder}}"withString:htmlReplaceString];

//Temp目錄下的js文件(temp文件和jquery庫)在根路徑佩伤,因此需要在加載HTMLString時指定根路徑

NSString*basePath = [[NSBundlemainBundle]bundlePath];

NSURL*baseURL = [NSURLfileURLWithPath:basePath];

//加載HTMLString

[_webViewloadHTMLString:tempHtmlbaseURL:baseURL];

以上代碼加上本地的temp文件就可以實(shí)現(xiàn)一個html數(shù)據(jù)的懶加載,但是有時候我們不單單是在一個界面只加載一個webview晦毙,比如說在tableview的頭視圖上加載一個webview生巡,但是webview懶加載時通過?

[webViewstringByEvaluatingJavaScriptFromString:@"document.body.offsetHeight;"]

計(jì)算出來的高度是不包含懶加載的圖片的高度的,如果圖片有占位圖那么這里計(jì)算出來的高度只是文字的高度與占位圖的高度的和见妒,因此就需要在圖片動態(tài)加載的過程中動態(tài)的來計(jì)算webview的高度孤荣。

在這里通過給webview里面的scrollview的contentSize設(shè)置一個監(jiān)聽

[_webView.scrollViewaddObserver:selfforKeyPath:@"contentSize"options:NSKeyValueObservingOptionNewcontext:nil];

當(dāng)圖片動態(tài)的加載出來以后contentSize就會改變因此就會被監(jiān)聽到來重新給webview設(shè)置高度。

- (void)observeValueForKeyPath:(NSString*)keyPath ofObject:(id)object change:(NSDictionary*)change context:(void*)context

{

if([keyPathisEqualToString:@"contentSize"]) {

//檢測contentSize的實(shí)時的高度

webViewHeight=_webView.scrollView.contentSize.height;

if(_webView.height==webViewHeight) {//實(shí)時高度和上次webView的高度作比較须揣,如果相等了說明圖片全部加載完成盐股,否則沒有則需要重新給webview高度賦值并且刷新tableview

return;

}

dispatch_async(dispatch_get_main_queue(), ^{

//重新將webview的高度設(shè)置為scrollview的內(nèi)容高度

_webView.frame=CGRectMake(10,60,MainScreenWidth-10,webViewHeight+30);

//重新給headerView的frame賦值

_upView.frame=CGRectMake(0,0,UI_SCREEN_WIDTH,60+webViewHeight+90+70);

_tableView.tableHeaderView=_upView;

[_tableViewreloadData];

});

}

}

這里遇到一個小坑:當(dāng)占位圖的高度比實(shí)際圖片的高度高的時候webview的高度還是文字和占位圖的高度的和,就會在底部留出一個空白區(qū)域耻卡,目前還沒有好的方法解決只能用高度比較小的占位圖?? ? ?如果大家有好的解決辦法歡迎積極分享疯汁。


demo下載地址 ?demo傳送門

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市卵酪,隨后出現(xiàn)的幾起案子幌蚊,更是在濱河造成了極大的恐慌,老刑警劉巖溃卡,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件溢豆,死亡現(xiàn)場離奇詭異,居然都是意外死亡塑煎,警方通過查閱死者的電腦和手機(jī)沫换,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來最铁,“玉大人讯赏,你說我怎么就攤上這事±湮荆” “怎么了漱挎?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長雀哨。 經(jīng)常有香客問我磕谅,道長私爷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任膊夹,我火速辦了婚禮衬浑,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘放刨。我一直安慰自己工秩,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布进统。 她就那樣靜靜地躺著助币,像睡著了一般。 火紅的嫁衣襯著肌膚如雪螟碎。 梳的紋絲不亂的頭發(fā)上眉菱,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天,我揣著相機(jī)與錄音掉分,去河邊找鬼俭缓。 笑死,一個胖子當(dāng)著我的面吹牛叉抡,可吹牛的內(nèi)容都是我干的尔崔。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼褥民,長吁一口氣:“原來是場噩夢啊……” “哼季春!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起消返,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤载弄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后撵颊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宇攻,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年倡勇,在試婚紗的時候發(fā)現(xiàn)自己被綠了逞刷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡妻熊,死狀恐怖夸浅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情扔役,我是刑警寧澤帆喇,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站亿胸,受9級特大地震影響坯钦,放射性物質(zhì)發(fā)生泄漏预皇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一婉刀、第九天 我趴在偏房一處隱蔽的房頂上張望吟温。 院中可真熱鬧,春花似錦路星、人聲如沸溯街。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至挥等,卻和暖如春友绝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背肝劲。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工迁客, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人辞槐。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓掷漱,卻偏偏與公主長得像,于是被迫代替她去往敵國和親榄檬。 傳聞我的和親對象是個殘疾皇子卜范,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

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