今回はJSでページスクロールバーを判定する場合の注意点を紹介します。実際の事例を見てみましょう。
はじめに
最近、プラグインを作成する過程で、検索後にスクロールバーがあるかどうかを判断するためにJSを使用する必要があります。一般的な方法は似ていますが、どれも少し冗長です。コードが十分に簡潔ではありません。最後に、さまざまな方法を参考にして、比較的簡単な方法を書きました。スクロール バーを判断する際には、スクロール バーの幅も計算する必要があります。これについては、この記事で説明します。
なぜスクロール バーを判断する必要があるのですか
スクロール バーを判断する必要性は、ポップアップ ウィンドウ プラグインでよく使用されます。これは、ほとんどのポップアップ ウィンドウが overflow: hidden を追加するためです。
属性 (ページが比較的長い場合) その場合、この属性を追加するとページが揺れます。 overflow: hidden
的属性,如果页面比较长的话,添加这个属性之后页面会有晃动。
为了增强用户体验,通过判断是否有滚动条而添加 margin-left
属性以抵消 overflow: hidden
之后的滚动条位置。
判断是否有滚动条的方法
其实只需要一行 JS 就可以,测试兼容 IE7
function hasScrollbar() { return document.body.scrollHeight > (window.innerHeight || document.documentElement.clientHeight); }
一般情况下,使用 document.body.scrollHeight
> window.innerHeight
就可以判断。
但是在 IE7,IE8 中 window.innerHeight
为 underfined
,所以为了兼容 IE7、IE8,需要使用document.documentElement.clientHeight
属性计算窗口高度。
计算滚动条宽度的方法
还是以弹窗为例,因为 IE 10 以上以及移动端浏览器的滚动条都是不占据页面宽度的透明样式(其中 IE 10 以上浏览器可以通过 CSS 属性还原原始的滚动条样式),所以为了进一步增强用户体验,我们还需要计算滚动条的宽度,根据情况添加合理的 margin-left
数值。
计算滚动条宽度的方法比较简单,新建一个带有滚动条的 p 元素,通过该元素的 offsetWidth
和 clientWidth
的差值即可获得,我在此借鉴 Magnific-popup
中的方法
function getScrollbarWidth() { var scrollp = document.createElement("p"); scrollp.style.cssText = 'width: 99px; height: 99px; overflow: scroll; position: absolute; top: -9999px;'; document.body.appendChild(scrollp); var scrollbarWidth = scrollp.offsetWidth - scrollp.clientWidth; document.body.removeChild(scrollp); return scrollbarWidth; }
总结
使用 JS 实现一个功能可能并不困难,但作为编程人员应该时刻思考如何更简单更优雅的实现这个功能,并且时刻以提升用户体验为原则。对于条件判断,也许十行的逻辑判断可能只需要一行,最近感受极为深刻,而且要善于使用三元表达式替代 if..else
margin-left
属性を追加して、 overflow: hidden
の後にスクロール バーがあるかどうかを判断してスクロール バーの位置をオフセットします。 。
スクロールバーがあるかどうかを確認する方法
実際、必要なJSは1行だけですrrreee
通常は、document.body.scrollHeight
を使用します。 > window.innerHeight
で判断できます。
ただし、IE7 および IE8 では、window.innerHeight
は underfineed
であるため、IE7 および IE8 と互換性を持たせるためには、document.documentElement を使用する必要があります。 .clientHeight
属性 ウィンドウの高さを計算します。
スクロールバーの幅の計算方法
を追加する必要もあります。状況に応じて margin-left
の値を変更します。 🎜🎜🎜🎜スクロールの幅の計算方法bar は比較的単純です。スクロール バーを含む新しい p 要素を作成します。これは、要素の offsetWidth
と clientWidth
の差によって取得できます。 >Magnific-popup はこちらです。コード内のメソッド>🎜rrreee🎜🎜概要🎜🎜🎜 JS を使用して関数を実装することは難しくないかもしれませんが、プログラマーとして、この関数をどのように実装するかを常に考えておく必要があります。シンプルかつエレガントに、常にユーザーエクスペリエンスの向上に焦点を当てています。条件判定に関しては、10 行の論理判定が 1 行で済むかもしれないと最近感心していますが、コードを効率化するために if..else
の代わりに 3 項式を使用するのが得意です。 🎜🎜この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。 🎜🎜推奨読書: 🎜🎜🎜応答ライトバックを適用してページをレンダリングする方法🎜🎜🎜🎜🎜JSを使用してアニメーションプログレスバー関数を作成する🎜🎜🎜以上がJSはページのスクロールバーを決定しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。