WKWebView的坑之圖片顯示不完全

最近在做iPad Pro適配時遇到了WKWebView圖片顯示不完全的坑

在顯示網(wǎng)頁中的大尺寸圖片時屠凶,圖片顯示不完整膝宁,有些是下方不顯示憎茂,有些是下方和右側都不顯示挚躯。流程如下

第一類情況

1. APP下方題目卡片初始狀態(tài)

在卡片出現(xiàn)時,顯示了WKWebView上部內(nèi)容形葬。
2. APP下方題目卡片展開狀態(tài)

點擊卡片下方展開按鈕或者上劃手勢合呐,展開卡片,可以看到更多網(wǎng)頁內(nèi)容笙以,但是下方圖片無內(nèi)容成白色淌实。滑動圖片后網(wǎng)頁內(nèi)容圖片刷新猖腕,顯示正常拆祈,如下
3. APP下方題目卡片拖動后顯示

第二類情況

如果WKWebView的初始狀態(tài)為不可見時,如下

4. APP下方題目卡片初始狀態(tài)

點擊展開卡片倘感,顯示的圖片只有左上角一小條放坏,其他內(nèi)容缺失,如下
5. APP下方題目卡片展開狀態(tài)

同樣滑動后頁面會刷新老玛,圖片顯示恢復正常淤年。
6. APP下方題目卡片拖動后顯示

原因分析

WKWebView相比UIWebView提高了頁面渲染載入速度,其中也包括只對展示給用戶可見的內(nèi)容進行渲染蜡豹,這樣可以大大提高載入速度互亮。如我遇到的圖片問題,WKWebView會把圖片分割成多塊余素,如下圖A-F六塊區(qū)域。

WKWebView對圖片分割成多塊渲染

在第一類情況炊昆,由于A/B/C塊都是用戶可見區(qū)域桨吊,所以WKWebView對這三塊區(qū)域進行了渲染,而D/E/F塊都沒有渲染凤巨。所以展開卡片時视乐,他也呈現(xiàn)空白狀態(tài),圖片缺失敢茁。
第二類情況則是所有區(qū)域都不在用戶可視范圍內(nèi)佑淀,所以他僅對A塊渲染,展開后B/C/D/E/F都為空白彰檬,圖片缺失伸刃。這個可以在XCodeDebug View Hierarchy中得到驗證谎砾,完整渲染的有六個區(qū)域,第一種情況三個區(qū)域捧颅,第二種狀況只有一種區(qū)域景图。

解決辦法

填坑辦法就是強制讓WKWebView重新渲染一次,代碼如下

[_webView setNeedsLayout];

我是在展開卡片時增加了WKWebView強制重新渲染的代碼實現(xiàn)碉哑。而對于網(wǎng)上提到比較多的挚币,在UITableView中添加WKWebView圖片載入不全的情況可以在- (void)scrollViewDidScroll:(UIScrollView *)scrollView中增加強制重新渲染的代碼來解決。聲稱這個坑在iOS11中得到了修復扣典,但是我的11.3的iPad Pro還是遇到了這個問題??妆毕,可能是我們的WKWebView操作沒有觸發(fā)重新渲染吧。

----------------------------------------------- 編輯于20180821 -------------------------------------------------------
最近出現(xiàn)了在iOS 8.2系統(tǒng)下圖片顯示過大贮尖,超出屏幕的問題笛粘。可以通過addUserScript解決远舅,如下

            NSString *jScript = @"var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'width=device-width'); document.getElementsByTagName('head')[0].appendChild(meta);";
            WKUserScript *wkUScript = [[WKUserScript alloc] initWithSource:jScript injectionTime:WKUserScriptInjectionTimeAtDocumentEnd forMainFrameOnly:YES];
            WKUserContentController *wkUController = [[WKUserContentController alloc] init];
            [wkUController addUserScript:wkUScript];
            [[_webView configuration].userContentController addUserScript:wkUScript];

Reference List

WKWebView not rendering correctly in iOS 10
使用WKWebView 適應屏幕尺寸

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末闰蛔,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子图柏,更是在濱河造成了極大的恐慌序六,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蚤吹,死亡現(xiàn)場離奇詭異例诀,居然都是意外死亡,警方通過查閱死者的電腦和手機裁着,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門繁涂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人二驰,你說我怎么就攤上這事扔罪。” “怎么了桶雀?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵矿酵,是天一觀的道長。 經(jīng)常有香客問我矗积,道長全肮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任棘捣,我火速辦了婚禮辜腺,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己评疗,他們只是感情好测砂,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著壤巷,像睡著了一般邑彪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胧华,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天寄症,我揣著相機與錄音,去河邊找鬼矩动。 笑死有巧,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的悲没。 我是一名探鬼主播篮迎,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼示姿!你這毒婦竟也來了甜橱?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤栈戳,失蹤者是張志新(化名)和其女友劉穎岂傲,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體子檀,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡镊掖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了褂痰。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亩进。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖缩歪,靈堂內(nèi)的尸體忽然破棺而出归薛,到底是詐尸還是另有隱情,我是刑警寧澤匪蝙,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布主籍,位于F島的核電站,受9級特大地震影響骗污,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜沈条,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一需忿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦屋厘、人聲如沸涕烧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽议纯。三九已至,卻和暖如春溢谤,著一層夾襖步出監(jiān)牢的瞬間瞻凤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工世杀, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留阀参,地道東北人。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓瞻坝,卻偏偏與公主長得像蛛壳,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子所刀,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

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