WordPress

WordPress★IE11でマウススクロールするとfixedで固定した背景画像がガタつくバグを修正

投稿日:

windows8+IE11とwindows10-IE11という閲覧条件のクライアントさまから、
「マウスでスクロールすると画像がガクガクしてるよ!」との報告。
急いで、原因を探ることになりました。

このページのもくじ

原因

発生条件は、CSSで背景画像に
position : fixed
background-attachment : fixed
どちらかを適用した場合に起こるようです。
この事象は、ページをマウスでスクロールした場合に起きて、スクロールバーを使った場合には発生しません。

Chrome・Firefox・Edge・Safariなどでは普通に見れますが、IEの時はマウスでページをスクロールすると、ページ中の固定背景画像がカクつきます。(泣)

この現象が起こるのは、IE(Internet Explorer)に実装されている「スムーズスクロール」が原因だそうです。
「スムーズスクロール」とは、マウスホイールを回転させると1行ずつ画面をスクロールさせるという機能で、デフォルトではONになっています。解除するには「インターネットオプション」から「詳細設定」「スムーズスクロールを使用する」のチェックを外す事で解決できます。

でも、これは個人設定なので、制作者側から操作する事ができない部分。
クライアントや閲覧者に「設定を直して」ともいえないし。。。

 

WordPressでの解決策

対処法をググるとネット上にいくつか紹介されていました。
いくつか試したところ、下のコードが有効でした。
掲載先のサイトがなくなると困るのでメモしておきます。

footer.phpの</body>ボディの閉じタグの直前あたりにそのまま貼り付けました。

<!--IE11とEdgeのバグ修正 マウススクロールで背景画像がガタつく-->
<script>
if(navigator.userAgent.match(/MSIE 10/i) || navigator.userAgent.match(/Trident\/7\./) || navigator.userAgent.match(/Edge\/12\./)) {
$('body').on("mousewheel", function () {
event.preventDefault();
var wd = event.wheelDelta;
var csp = window.pageYOffset;
window.scrollTo(0, csp - wd);
});
}
</script>

 

テストしたところ、カクカクとガタついていた背景画像がピタッと止まってくれました!

本サイトの内容に誤りや不正確な記述がある場合やサンプルに基づくいかなる結果も一切の責任を負いかねますので、あらかじめご了承ください。

-WordPress

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

関連記事

WordPress★「Search-Replace」で「The table “wp_ewwwio_queue” has no primary key.」っていうエラーがでたときの対処法

データベースの置換スクリプト「Search Replace」を実行する際に、事前テストでチェックするのがお約束。いつもはなにも問題がないのだけれど、「dry run」ボタンを押してテストすると、エラー …

WP★吹き出し風デザインをCSSだけでやる方法

ワードプレスでプラグインを使わずに、 HTMLとCSSだけで下のような感じの会話風レイアウトの作り方。   手順はこちら   [codepen_embed height=”400 …

WordPress★コメント入力フォームをカスタマイズする

  WordPressのバージョンは4.7.3 コメント入力フォームをカスタマイズする方法です。変更内容は 1)コメントの入力フォームで不要な部分を非表示にする 2)入力フォームの文言を自由に変更する …

WordPress|Twenty Nineteen 固定ページをカスタマイズするときに編集するファイル

themes > Twenty Nineteen > page.phpファイルを複製 複製してできたpage copy.phpファイルを子テーマのフォルダに移動 page copy.php …

WordPress★特定のページだけに「ある要素」を表示させたいとき

WordPressで、特定のページだけに「ある要素」を表示させたいときの テンプレートファイルへの書き方。 テンプレートファイル内の要素を表示させたい箇所に記述 要素のボリュームが少ない場合 =>テン …

サイト制作・グラフィック制作をしているデザイナーです。制作で躓いたことの備忘録としてこのブログを始めました。
たくさんの検索結果から、実際に何度も何度も自分で試してみて、自分に合うなと思った方法やうまくいった方法をこのブログに書き留めています。
プログラム関係のことはもっぱらコピペ派。
自分でゴリゴリ書くことはできません。。。プログラムが分かる人がうらやましいです。
そんな私でもなんとかサイト制作ができるのはグーグル先生と貴重な情報をおしげもなく公開してくださっているたくさんの方々のおかげ。
有志のみなさまに日々感謝しつつ制作させていただいています。