この記事では、簡単なドラッグ効果を実現するための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 に変換するサンプルコード
以下に、一般的な MySQL コマンドをいくつか示します。 -- データベース サービスを開始します...
目次繰り返しレンダリングループを避ける副作用の除去についてReact16.8 の新しい useEff...
MySQLのマスタースレーブ構成と原理、参考までに具体的な内容は以下のとおりです。 1. 環境の選択...
この記事では、VUEの具体的なコードを共有して、下部吸引ボタンを実装する例を紹介します。具体的な内容...
Baiduクラウドディスク:リンク: https://pan.baidu.com/s/1hv5rUW...
今日 テーブル名から * を選択します。ここで、to_days(時間フィールド名) = to_day...
テキストオーバーフローを表示するにはどうすればいいですか? どのようなニーズがありますか?単一行です...
目次1. V8ソース2. V8サービスターゲット3. V8の初期アーキテクチャIV. V8の初期アー...
MySQL 5.x と MySQL 8.0.X のいくつかの違いapplication.proper...
質問通常の開発では、プロジェクトを Tomcat にデプロイする場合、プロジェクトを war パッケ...
CentOS 7 の yum ソースには、MySQL を正常にインストールするための mysql-s...
1.1 nginxインストールパッケージとインストールスクリプトをクライアントにコピーし、スクリプト...
誰もがボックス モデルの構成を、内側から外側まで、コンテンツ、パディング、境界線、マージンについて知...
参考までに、mysql 5.7.20 / 5.7.21 をダウンロード、インストール、構成します。具...
目次結論は実践分析拡張機能要約する結論は親コンポーネントでカスタム イベントが定義されている場合、子...