この記事では、簡単なドラッグ効果を実現するためのjsの具体的なコードを参考までに共有します。具体的な内容は次のとおりです。 1. ドラッグの基本的な効果アイデア: マウスがボックス上で押されると、移動の準備が整います(イベントがオブジェクトに追加されます) マウスが動くと、ボックスはマウスに追従します(イベントがページに追加されます) マウスを離すと、ボックスの動きが止まります(イベントがページに追加されます) var o = document.querySelector('div'); //マウスダウン o.onmousedown = function (e) { //ボックスに対するマウスの位置 var offsetX = e.clientX - o.offsetLeft; var offsetY = e.clientY - o.offsetTop; //マウスの移動 document.onmousemove = function (e) { o.style.left = e.clientX - offsetX + "px"; o.style.top = e.clientY - offsetY + "px"; } //マウスアップ document.onmouseup = function () { ドキュメント.onmousemove = null; ドキュメント.onmouseup = null; } } 2. ドラッグアンドドロップの問題ブラウザのデフォルトの動作(テキストと画像はドラッグ可能)により、ボックスにテキストが表示されたり、ボックス自体が画像である場合は、 return false を設定してデフォルトの動作を回避できます。ただし、このデフォルトの動作のインターセプトは、IE の下位バージョンには適用できません。グローバル キャプチャを使用して IE の問題を解決できます。 グローバルキャプチャ グローバル キャプチャは、IE の下位バージョンにのみ適用されます。 <button>btn1</button> <button>btn2</button> <スクリプト> var bts = document.querySelectorAll('ボタン') bts[0].onclick = 関数(){ コンソールログ(1); } bts[1].onclick = 関数(){ コンソールログ(2); } // bts[0].setCapture() //グローバルキャプチャを追加 // bts[0].releaseCapture() ; //グローバルキャプチャを解除</script> 指定されたノードにグローバル キャプチャが追加されると、ページ上の他の要素は同じタイプのイベントをトリガーしなくなります。 3. ドラッグアンドドロップのフルバージョンvar o = document.querySelector('div'); //マウスダウン o.onmousedown = function (e) { if (o.setCapture) { //IE 下位バージョン o.setCapture() } e = e || ウィンドウイベント //ボックスに対するマウスの位置 var offsetX = e.clientX - o.offsetLeft; var offsetY = e.clientY - o.offsetTop; //マウスの移動 document.onmousemove = function (e) { e = e || ウィンドウイベント o.style.left = e.clientX - offsetX + "px"; o.style.top = e.clientY - offsetY + "px"; } //マウスアップ document.onmouseup = function () { ドキュメント.onmousemove = null; ドキュメント.onmouseup = null; o.releaseCaptureの場合{ o.releaseCapture(); //グローバルキャプチャを解放する} } return false; //標準ブラウザのデフォルトの動作} 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: nginx を使用して http を https に変換するサンプルコード
1. フォーム<form id="" name="" ...
目次識別子の長さ制限権限テーブルの範囲フィールドの長さ制限データベースとテーブルの数の制限テーブルサ...
この例で使用されているMySQLのバージョンはmysql-8.0.15-winx64です。 1. z...
問題の説明長い間アカウントパスワードを入力して Zabbix にログインしていないため、管理者パスワ...
目次1. トリガーソリューション2. パーティションテーブルソリューション3. 一般的な表領域ソリュ...
理由: MySQL 5.7.5 以降では機能依存関係の検出が実装されています。 only_full_...
<br />原文: http://jorux.com/archives/what-is-...
私はコーディングが大好きです。コーディングすると幸せになります!みなさんこんにちは、Counterで...
目次MySQL マスタースレーブ同期原理の簡単な分析1. マスタースレーブとは何ですか? 2. 主従...
will-change は、要素にどのような変更が行われるかをブラウザに伝え、ブラウザが事前に最適化...
mysql-connector-java.jar パッケージのチュートリアルをダウンロードします: ...
Docker の使用に関するヒント1. 停止したDockerコンテナをすべてクリーンアップする停止し...
目次1. 関数の定義1.1 JavaScript の関数1.2 TypeScriptの関数2. オプ...
1. MMMの紹介: MMM は、Multi-Master Replication Manager...
毎日jQueryプラグイン - 検索履歴を作成するためのものです。参考までに、具体的な内容は次のとお...