検索
ホームページウェブフロントエンドCSSチュートリアルCSS 位置レイアウトを使用して要素のドラッグを実装するためのヒント

CSS Positions布局实现元素拖动的技巧

要素のドラッグを実装するための CSS 位置レイアウト手法には、特定のコード例が必要です。

Web デザインでは、要素のドラッグは一般的な機能要件です。 CSS Positions レイアウトを使用すると、外部ライブラリや JavaScript に頼ることなく、要素のドラッグ機能を簡単に実装できます。この記事では、要素のドラッグを実装するためのいくつかのテクニックを共有し、具体的なコード例を示します。

1. CSS ポジションの概要
CSS ポジションは、Web ページ内の要素の位置を特定するのに役立つレイアウト テクノロジです。これには、静的、相対、絶対、固定の 4 つの属性が含まれます。要素のドラッグ機能を実装する際には、相対属性と絶対属性に特別な注意を払う必要があります。

  1. static (デフォルト属性): 要素はドキュメント フローに従って通常どおり配置され、top、bottom、left、right 属性を使用して配置することはできません。
  2. relative: 要素の位置は、ドキュメント フロー内の要素の位置を参照し、top、bottom、left、right 属性を使用して微調整できます。
  3. absolute: 要素は、静的に配置されていない最も近い親要素を基準にして配置されます。静的に配置されていない親要素がない場合は、ドキュメントを基準にして配置されます。
  4. 修正: 要素はブラウザ ウィンドウを基準にして配置され、スクロールしても移動しません。

2. 要素のドラッグを実装する
要素のドラッグを実装するには、マウス イベント (mousedown、mousemove、mouseup) と CSS Positions プロパティを使用する必要があります。要素のドラッグを実装する基本的な手順は次のとおりです。

  1. ドラッグする必要がある要素に CSS スタイルを追加します。

    .draggable {
      position: absolute;
      cursor: move;
    }
  2. ドラッグ機能をトリガーするマウス イベント リスナーを追加します。

    const draggable = document.querySelector('.draggable');
    let isDragging = false;
    let offsetX = 0;
    let offsetY = 0;
    
    draggable.addEventListener('mousedown', function(e) {
      isDragging = true;
      offsetX = e.offsetX;
      offsetY = e.offsetY;
    });
    
    document.addEventListener('mousemove', function(e) {
      if (isDragging) {
     const x = e.clientX - offsetX;
     const y = e.clientY - offsetY;
     draggable.style.left = x + 'px';
     draggable.style.top = y + 'px';
      }
    });
    
    document.addEventListener('mouseup', function() {
      isDragging = false;
    });

上記のコードでは、まず querySelector を通じてドラッグする必要がある要素を取得し、mousedown イベントのリスナーを追加します。マウスが押されると、isDragging 状態を true に設定し、ドラッグされた要素を基準としたマウス クリック位置のオフセット (offsetX および offsetY) を保存します。次に、mousemove イベントの isDragging のステータスを確認し、true の場合はマウスの移動距離を計算し、drag 要素の left 属性と top 属性を変更することでドラッグ効果を実現します。最後に、mouseup イベントで isDragging のステータスを false に設定して、ドラッグを停止します。

3. 概要
CSS Positions レイアウトとマウス イベントを通じて、要素のドラッグ機能を実現できます。この記事では、要素のドラッグを実装するための基本的なコード例を示します。必要に応じて変更および拡張したり、要素のドラッグ範囲の制限やトランジション効果の追加などの機能を追加したりできます。この記事が、CSS Positions レイアウトを学習して適用して要素のドラッグ機能を実装するのに役立つことを願っています。

以上がCSS 位置レイアウトを使用して要素のドラッグを実装するためのヒントの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
カーソルの次のレベルCSSスタイリングカーソルの次のレベルCSSスタイリングApr 23, 2025 am 11:04 AM

CSSを備えたカスタムカーソルは素晴らしいですが、JavaScriptを使用して次のレベルに物事を引き出すことができます。 JavaScriptを使用して、カーソル状態間で移行し、カーソル内に動的テキストを配置し、複雑なアニメーションを適用し、フィルターを適用できます。

Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Apr 23, 2025 am 10:42 AM

2025年には、互いに互いに跳ね返る要素を伴うインタラクティブなCSSアニメーションは、CSSにPongを実装する必要はありませんが、CSSの柔軟性とパワーの増加はLee'の疑いを補強します。

UI効果にCSSバックドロップフィルターを使用しますUI効果にCSSバックドロップフィルターを使用しますApr 23, 2025 am 10:20 AM

CSSバックドロップフィルタープロパティを使用してユーザーインターフェイスをスタイルするためのヒントとコツ。バックドロップフィルターを複数の要素間でレイヤー化する方法を学び、それらを他のCSSグラフィカル効果と統合して、精巧なデザインを作成します。

微笑んでいますか?微笑んでいますか?Apr 23, 2025 am 09:57 AM

まあ、SVG'の組み込みのアニメーション機能は、計画どおりに非推奨されることはありませんでした。確かに、CSSとJavaScriptは負荷を運ぶことができる以上のものですが、以前のようにSmilが水中で死んでいないことを知っておくのは良いことです

「かわいい」は見る人の目にあります「かわいい」は見る人の目にありますApr 23, 2025 am 09:40 AM

イェーイ、テキストワラップのジャンプを見てみましょう:サファリテクノロジーのプレビューにかなり着陸してください!しかし、それがChromiumブラウザーでの仕組みとは異なることに注意してください。

CSS-Tricks XLIIIを記録しますCSS-Tricks XLIIIを記録しますApr 23, 2025 am 09:35 AM

このCSS-Tricksアップデートは、アルマナック、最近のポッドキャスト出演、新しいCSSカウンターガイド、および貴重なコンテンツを提供するいくつかの新しい著者の追加の大幅な進歩を強調しています。

Tailwind'の@Apply機能は、響きよりも優れていますTailwind'の@Apply機能は、響きよりも優れていますApr 23, 2025 am 09:23 AM

ほとんどの場合、人々はTailwind'の@Apply機能を紹介します。このように展示されたとき、@Applyはまったく有望な音をしません。だからobvio

私はリリースがないように感じます:正気な展開への旅私はリリースがないように感じます:正気な展開への旅Apr 23, 2025 am 09:19 AM

馬鹿のように展開することは、展開に使用するツールと複雑さの報酬と複雑さの減少との間の不一致になります。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!