ホームページ  >  記事  >  ウェブフロントエンド  >  jsでスクロールバーの幅を取得する方法(コード例)

jsでスクロールバーの幅を取得する方法(コード例)

不言
不言オリジナル
2018-08-11 15:49:003034ブラウズ

この記事の内容はjsでスクロールバーの幅を取得する方法(コード例)です。必要な方は参考にしていただければ幸いです。

アイデア: 要素を作成する際は、要素に境界線を設定せず、要素に overflowY:scroll を設定し、要素の offsetWidth-clientWidth に基づいてスクロール バーの幅を計算します。

コード:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>计算滚动条宽度</title>
</head>

<body>
    <script>
        // 封装获取滚动条宽度的方法
        function getScrollBarWidth() {
            var el = document.createElement("p"),
                styles = {
                    width: "100px",
                    height: "100px",
                    overflowY: "scroll"
                },
                i;

            // 这里很巧妙呀,先定义了一个styles对象,里面写了各种样式值,然后通过for in将这个对象的值赋给p元素的style对象
            // 而不用通过style.width=***等来给p的样式对象赋值。
            for (i in styles) {
                el.style[i] = styles[i];
            }

            // 将元素加到body里面
            document.body.appendChild(el);

            var scrollBarWidth = el.offsetWidth - el.clientWidth;
            //将添加的元素删除
            el.remove();
            return scrollBarWidth;
        }

        console.log(getScrollBarWidth()); // 注意这里imac得到的结果为0,因为imac的滚动条是没有宽度的。
    </script>
</body>

</html>

関連する推奨事項:

JS モジュール性の実装方法は何ですか? jsのモジュール化について解説

jsでcssアニメーションを書くには? jsでCSSアニメーションを書く方法(コード)

以上がjsでスクロールバーの幅を取得する方法(コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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