マウスのドラッグ効果を実現するJavaScript

マウスのドラッグ効果を実現するJavaScript

この記事では、マウスドラッグ効果を実現するためのJavaScriptの具体的なコードを参考までに紹介します。具体的な内容は次のとおりです。

今回のエフェクト画像は以下の通り。

この実験の難しさは、ボックスとマウスの相対的な位置を変えずに、マウスを押したり動かしたりすることでドラッグ効果を実現することだと思います。

ドラッグ効果を実現するにはどうすればいいですか?

マウスが押された状態、マウスが移動された状態、マウスが上げられた状態をそれぞれ表す、 onmousedownonmousemoveonmouseup 3 つの関数を使用する必要があります。

マウス押下のコールバック関数では、 clientXclientYを通じてマウスの初期位置を取得し、 offsetLeftoffsetTopを通じてボックスの初期位置を取得し、マウスの初期位置とボックスの初期位置の差を計算する必要があります。

マウス移動コールバック関数では、マウスの位置と以前に計算された差に基づいてボックスの現在の位置を取得し、左と上の値を変更する必要があります。位置を絶対に設定することを忘れないでください (忘れていたので...)

マウスアップのコールバック関数では、 onmousemoveonmouseup値を null に設定して、マウスの移動とマウスアップをクリアする必要があります。

こちらも注目! ! !

マウス移動機能とマウスリフト機能は、マウス押下機能内に記述する必要があります。これは、マウスが押された後の後続の動作を設計する必要があるためです。次の点が非常に重要です。

マウスダウン機能はdivにあり、マウス移動とマウスアップ機能はドキュメントにあります。

div内でマウスを動かすのではなく、ページ全体を動かしたいからです

重要なポイントはおそらく次のとおりです。コードは次のとおりです。

<!DOCTYPE html>
<html lang="ja">
<ヘッド>
    <メタ文字セット="UTF-8">
    <meta http-equiv="X-UA-compatible" content="IE=edge">
    <meta name="viewport" content="width=デバイス幅、初期スケール=1.0">
    <title>ドキュメント</title>
    <スタイル>
        #箱{
            幅: 100ピクセル;
            高さ: 100px;
            背景色: アクアマリン;
            境界線の半径: 14px;
            ボックスの影: 2px 2px 6px rgba(0,0,0,.3);

            /* 皆さん、位置を設定せずに左に移動して変更したいとします。 。 。 */
            位置: 絶対;
        }
    </スタイル>
</head>
<本文>
    <div id="box"></div>
    <スクリプト>
        box = document.getElementById("box"); とします。
        box.onmousedown=関数(イベント){
            disx = event.clientX-box.offsetLeft; とします。
            disy=event.clientY-box.offsetTop とします。
            //これはbox.onmousemoveではなく、document.onmousemoveです
            document.onmousemove=関数(イベント){
                box.style.left=event.clientX-disx+'px';
                box.style.top=event.clientY-disy+'px';
            }

            //ommousedownに書き込む document.onmouseup=function(){
                //両方をnullに設定する
            ドキュメント.onmousemove=null;
            ドキュメント.onmouseup=null;
            false を返します。
        }
        }
        
    </スクリプト>
</本文>
</html>

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • JavaScript を使用してマウス ドラッグ イベントを実装する
  • マウスをドラッグしてサブウィンドウを移動するJS実装
  • jsはマウスをドラッグして画像を切り替えるメソッドを実装します
  • マウスドラッグ複数選択機能を実現する js の例
  • JS マウスドラッグ例の分析
  • jsMindはマウスをドラッグしてノードの位置を調整します
  • js はマウスドラッグ div を左右にスライドすることを実現します
  • JavaScript マウスドラッグイベントの詳細な説明
  • マウスのドラッグとズームを実現する js div サンプルコード
  • JavaScriptはキャンバスを使用してマウスドラッグ機能を実装します

<<:  MySQL をクリーンにアンインストールする方法 (テスト済みで効果的)

>>:  CSSは左固定と右適応のレイアウト方法を実現します

推薦する

vue3とvue2の利点の比較

目次利点1: diffアルゴリズムの最適化利点2: ホイスト静的静的リフティング利点3: cache...

HTML ヘッド構造

以下では、よく使われるヘッド構造と、各タグや要素の意味や使用シーンを紹介します(この記事は、Yisi...

JavaScript 関数のコンテキストのルールは何ですか?

目次1. ルール 1: Object.Method() 1.1 ケース1 1.2 ケース2 1.3 ...

携帯電話に GreasyFork js スクリプトをインストールするチュートリアル

目次序文1. Iceraven ブラウザ (Firefox) (Android) 2. (アンドロイ...

Vue の echarts ツールチップにクリック イベントを追加する詳細な説明

目次必要回避策1. ツールチップを設定する2. hookToolTip変数を定義する3. メソッド内...

Hbase 入門

1. HBaseの概要1.1 HBaseとはHBase は、高い信頼性、高いパフォーマンス、列ストレ...

Mysql ルートユーザーアカウントのパスワードをリセットする問題を解決する

問題の説明: mysqladmin.exe を使用してコマンドを実行すると、次のエラー メッセージが...

MySQL ルートパスワードエラー番号 1045 の解決方法

MySQLサービスを停止するWindowsでは、マイコンピュータを右クリック--管理--サービスと...

初心者向けのMySQLデータベースとテーブルDDLの作成と操作の学習

目次1. データベースを操作する1.1 データベースを作成する1.2 データベースをクエリする1.3...

Nginx でファイル ホットリンク保護サービスを構築する方法を学ぶ例

序文多くのサイトが、ポイントやゴールドコインなど、情報のダウンロードに料金を請求していることは誰もが...

mysql バッチで大量のデータを削除する

mysql バッチで大量のデータを削除する1000万件のレコードを持つテーブル(syslogs)があ...

Linux の chown コマンドと chmod コマンドの違いの詳細な説明

Linux システムでは、chmod コマンドと chown コマンドの両方を使用して権限を設定でき...

iframeノードの初期化の問題に関する議論

今日、ふとリッチテキストエディタの制作原理を見直してみようと思いました。それで、彼は何も言わずにそれ...

nginx httpモジュールのデータ保存構造の概要

このセクションから、http モジュールの実装原理について説明します。http モジュールで非常に重...

Echarts バー水平棒グラフのサンプルコード

目次横棒グラフデータとスタイルを動的に更新するeChartsの幅と高さの適応の問題を解決する縦棒グラ...