Vueはスクロールバースタイルを実装します

Vueはスクロールバースタイルを実装します

ここに画像の説明を挿入

最初はブラウザのスクロールバーのスタイルを変更して効果を実現したいと思っていましたが、情報を調べてみると、ブラウザのスクロールバーでは幅と位置を変更できないことがわかりました。自分で書くしかありませんでした。まず、スクロールバーのスタイル

<div class="scrollBar" v-if="roleList.length > 5">
        <div
          クラス="ボックス"
          @mousedown="移動"
          v-bind:style="{ 幅: アクティブ幅 + 'px' }"
        </div>
      </div>

スタイル

.スクロールバー{
  幅: 500ピクセル;
  高さ: 6px;
  背景: #d5dbf5;
  マージン: 0 自動;
  上マージン: 72px;
  境界線の半径: 4px;
  位置: 相対的;

  。箱 {
    幅: 30ピクセル;
    高さ: 100%;
    背景: #fff;
    境界線の半径: 4px;
    位置: 絶対;
    左: 0;
  }
  .box:hover {
    カーソル: ポインタ;
  }
}

スクロールエリアのスタイルはここには書かれていません

1 まずスクロールバースライダーの幅です

マウント() {
    //スクロール領域の幅 ここではユーザー リストをトラバースしているので、リストの長さを取得します * 各 li の幅が合計幅です let bgWidth = this.$refs.liList.clientWidth * this.roleList.length;
    // 表示領域の幅 1065 これは、上の画像の白い背景ボックスの幅です // スライダーの幅 500 は、スクロール バーの幅です この幅は、スライダーがスライドできる距離を取得するために計算されます。これについては、後で説明します this.activewidth = 500 * (1065 / bgWidth);
  },

2 スライダーにマウスイベントを追加する

移動する{
      // ターゲット要素を取得します。let odiv = e.target;
      //スクロール領域
      //要素に対するマウスの位置を計算します。let disX = e.clientX - odiv.offsetLeft;
      // スクロールバーがスクロールできる距離 let viewArea = 500 - this.activewidth;
      //スクロール領域の幅 let bgWidth = this.$refs.liList.clientWidth * this.roleList.length;
      ドキュメント.onmousemove = (e) => {
        // マウスが押されて移動されたイベント // 要素に対するマウスの位置をマウスの位置から減算して、要素の位置を取得します。let left = e.clientX - disX;
        //left < 0 はスライダーが左端に到達したことを意味します //または left > viewArea はスライダーが右端に到達したことを意味しますif (left < 0 || left > viewArea) {
          //console.log("終了しました");
          // このとき、イベントをクリアする必要があります。そうしないと、スライダーがスクロール バー領域から外れてしまいます。 document.onmousemove = null;
        } それ以外 {
         //スライダーのスライド距離 odiv.style.left = left + "px";
          //スクロール領域のスライド距離 = スクロール領域の幅 * (スライダーのスライド距離 / 500)
          this.$refs.ScrollArea.style.left =
            "-" + bgWidth * 左 / 500 + "px";
        }
      };
      ドキュメント.onmouseup = (e) => {
        ドキュメント.onmousemove = null;
        ドキュメント.onmouseup = null;
      };
    },

これで、Vue でスクロール バー スタイルを実装する方法に関するこの記事は終了です。Vue でスクロール バーを実装する方法に関するより関連性の高いコンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Vueは2つのエリアスクロールバーの同期スクロールを実装します
  • Vue.js デスクトップ カスタム スクロール バー コンポーネント 美化 スクロール バー VScroll
  • Vueはスクロールバーを記憶し、ドロップダウンの読み込みを実装するのに最適な方法です
  • Vueでスクロールバーのスタイルを変更する方法
  • Vue はデータのレンダリング後にスクロールバーの位置制御を実装します (推奨)
  • Vue スクロールバープラグインの実装コード
  • Vueフレームワークでカスタムスクロールバー(easyscroll)を実装する方法
  • Vue でスクロールバーのスタイルを変更する方法

<<:  Centos7 Zabbix3.4 メールアラーム設定(メール内容がxx.bin添付ファイルになる問題の解決)

>>:  システム エラー 1067 のため、MySQL 5.6 解凍バージョン サービスを開始できません

推薦する

タブ切り替え効果を実現するJavaScript

この記事では、タブ切り替え効果を実現するためのJavaScriptの具体的なコードを参考までに紹介し...

MySQL 学習ノート: 完全な SELECT ステートメントの使用例と詳細な説明

この記事では、MySQL 学習ノートの select ステートメントの完全な使用方法を例を使用して説...

Dockerは単一のイメージを使用して複数のポートにマッピングします

必要:公式サイトのリソースサーバーは確かに1つのインスタンスでは使えず、複数のインスタンスを一緒に使...

Xshell を使用して VMware 上の Linux 仮想マシンに接続する (グラフィック手順)

はじめに: 最近 Hadoop プラットフォームの構築を勉強し始めたので、ローカルマシンに VMwa...

Nest.js 環境変数の設定とシリアル化の詳細な説明

環境変数の設定の簡単な説明プログラムは、環境によって異なる環境変数を必要とします。たとえば、実稼働環...

HTMLは正規表現を使用してテーブルの例をテストします

以下は、HTML で正規表現を使用してテーブルをチェックするサンプル コードです。具体的なコードの内...

Vite2.x に基づく Vue 3.x プロジェクトの実装

Vue 3.x プロジェクトの作成 npm init @vitejs/app my-vue-app ...

インラインブロックを使用した複数のdiv間の間隔はプログラミング方法とは異なります

inline-block について学習しているときに、境界線と inline-block を持つ複数...

MySQLストレージ時間タイプの選択に関する問題の説明

MySQL では、datetime 型は通常、時間を保存するために使用されますが、現在では多くのシス...

Docker で MySQL を起動したときに SQL 文を自動的に実行する方法

Docker で MySQL コンテナを作成する場合、コンテナの起動後にデータベースとテーブルが自動...

CSS (カスケーディング スタイル シート) の一般的な用語の概要

CSS を使用する場合は、DOCTYPE (ドキュメント タイプ定義) を記述することを忘れないでく...

Windows システムに MySQL を素早くインストールして展開する方法 (グリーンの無料インストール バージョン)

まずは緑色の無料インストール版のMySQLをダウンロードします。任意のフォルダに入れて構いません。今...

Linux mysql-5.6 でルート パスワードをリセットする方法

1. MySQL サービスが起動しているかどうかを確認します。起動している場合は、MySQL サービ...

MySQL 8.0.15 のインストールと設定方法のグラフィックチュートリアル (Win10 Home バージョン 64)

超初心者の私は、MySQL を学び始めたばかりで、インストール プロセス中に多くの問題に遭遇しました...