ホームページ  >  記事  >  ウェブフロントエンド  >  ページにスクロール バーがあるかどうかを判断するために JS にはどのようなプロパティが必要ですか?

ページにスクロール バーがあるかどうかを判断するために JS にはどのようなプロパティが必要ですか?

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-02 10:46:012135ブラウズ

今回は、ページにスクロール バーがあるかどうかを判断するために JS のどのようなプロパティが使用できるか、また、JS がページにスクロール バーがあるかどうかを判断するためにどのような notes があるかを説明します。実際のケースを見てみましょう。

はじめに

最近、プラグインを作成する過程で、検索後にスクロールバーがあるかどうかを判断するためにJSを使用する必要があります。一般的な方法は似ていますが、どれも少し冗長です。コードが十分に簡潔ではありません。最後に、さまざまな方法を参考にして、比較的簡単な方法を書きました。スクロールバーを判断する際には、スクロールバーの幅も計算する必要があります。この記事で説明します。

なぜスクロール バーを判断する必要があるのですか

スクロール バーを判断する必要性は、ポップアップ ウィンドウ プラグインでよく使用されます。これは、ほとんどのポップアップ ウィンドウで <a href="%E3%81%8C%E8%BF%BD%E5%8A%A0%E3%81%95%E3%82%8C%E3%82%8B%E3%81%9F%E3%82%81%E3%81%A7%E3%81%99%E3%80%82" target="_blank">overflow<code><a href="http://www.php.cn/wiki/923.html" target="_blank">overflow</a>: hidden 的属性,如果页面比较长的话,添加这个属性之后页面会有晃动。

为了增强用户体验,通过判断是否有滚动条而添加 <a href="http://www.php.cn/wiki/937.html" target="_blank">margin-left</a> 属性以抵消 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 : hidden 属性。ページが比較的長い場合、この属性を追加するとページが揺れます。

ユーザーエクスペリエンスを向上させるために、<a href="http://www.php.cn/wiki/937.html" target="_blank">margin-left</a><a href="http://www.php.cn/code/8418.html" target="_blank"> プロパティを追加します。 <code>overflow:hidden の後のスクロール バーの位置をオフセットします。

スクロールバーがあるかどうかを確認する方法

実際、必要なJSは1行だけです

rrreee通常は、document.body.scrollHeight を使用します。 > window.innerHeight で判断できます。
ただし、IE7 および IE8 では、window.innerHeightunderfineed であるため、IE7 および IE8 と互換性を持たせるためには、document.documentElement を使用する必要があります。 .clientHeight 属性 ウィンドウの高さを計算します。

スクロールバーの幅の計算方法

は、IE 10以降およびモバイルブラウザのスクロールバーはページを占有しない透明なスタイルであるため、例としてポップアップウィンドウに基づいています。 width (ブラウザ IE 10 以降では CSS プロパティを使用して元のスクロール バー スタイルを復元できます) そのため、ユーザー エクスペリエンスをさらに向上させるために、スクロール バーの幅を計算し、適切な を追加する必要もあります。状況に応じて margin-left の値を変更します。


スクロールの幅の計算方法bar は比較的単純です。スクロール バーを含む新しい p 要素を作成します。これは、要素の offsetWidthclientWidth の差によって取得できます。 >Magnific-popup はこちらです。コード内のメソッド>

rrreee🎜🎜概要🎜🎜🎜 JS を使用して関数を実装することは難しくないかもしれませんが、プログラマーとして、この関数をどのように実装するかを常に考えておく必要があります。シンプルかつエレガントに、常にユーザーエクスペリエンスの向上に焦点を当てています。 条件判断 🎜 については、おそらく 10 行の論理判断が 1 行で済むのではないかと最近しみじみ感じました。また、if..else を置き換える三項 式🎜 の使用に優れている必要があります。コードを合理化します。 🎜🎜原則は、文書の高さが🎜視覚領域🎜の高さより大きいかどうかを判断することです。 🎜🎜この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。 🎜🎜推奨読書: 🎜🎜🎜vue.jsプロジェクトのnginxデプロイ手順の詳細な説明🎜🎜🎜🎜🎜一般的に使用される6つのJSソートアルゴリズムと比較🎜🎜🎜🎜🎜webpackソースコードでローダーメカニズムを使用する手順🎜🎜🎜

以上がページにスクロール バーがあるかどうかを判断するために JS にはどのようなプロパティが必要ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。