AndroidのWebview内でモーダルの背景固定処理が効かない
現在iOS,Androidのスマホアプリを作成しており、その中で一部WebページをWebViewで読み込んでいる箇所があります。
その中でHTMLで作成したモーダル表示に対して、JSでモーダル表示中は背景のスクロールをさせないように固定する処理を入れているのですが、こちらの処理がAndroidだけ効かず困っています。
背景固定の処理は下記になります。
該当のソースコード
JavaScript
1window.onload = function(){ 2 let $body = $('body'); 3 let scrollTop; 4 5 // スクロールを固定 6 function bodyFixedOn() { 7 scrollTop = $(window).scrollTop(); 8 $body.css({ 9 overflowY: 'hidden', 10 position: 'fixed', 11 top: -scrollTop 12 }); 13 } 14 15 // スクロールの固定を解除 16 function bodyFixedOff() { 17 $body.css({ 18 overflowY: 'auto', 19 position: '', 20 top: '' 21 }); 22 $(window).scrollTop(scrollTop); 23 } 24 25 // モーダル表示 26 openBtn.addEventListener('touchend',function(event){ 27 // 背景固定 28 bodyFixedOn(); 29 ・ 30 ・ 31 // その他モーダル表示処理 32 }); 33 34 // モーダル非表示 35 closeBtn.addEventListener('touchend',function(event){ 36 // 背景固定解除 37 bodyFixedOff(); 38 ・ 39 ・ 40 // その他モーダル非表示処理 41 }); 42}
補足情報(FW/ツールのバージョンなど)
Androidのバージョンは8,9,10,11で確認しています。
iOSは10,11,12で全て問題なく固定されます。
Androidではなにか特殊な処理が必要になるのでしょうか?
知見のある方教えていただければ幸いです。
どうぞよろしくお願い致します。
あなたの回答
tips
プレビュー