ホームページ > ウェブフロントエンド > フロントエンドQ&A > Vue はマウス ドラッグ コントロールの幅を実装します

Vue はマウス ドラッグ コントロールの幅を実装します

王林
リリース: 2023-05-11 12:49:37
オリジナル
2022 人が閲覧しました

Vue.js は人気のある JavaScript フレームワークであり、フレームワークであるだけでなく、非常に柔軟で強力なライブラリでもあります。このフレームワークにより、開発者はフロントエンド アプリケーションを効率的に実装できます。この記事では、Vue.jsを使ってマウスドラッグによる幅の制御を実装する方法を紹介します。

幅を制御するマウス ドラッグの実装は、境界バーやスライダーをドラッグしてコンテナーのサイズを変更したり、画像のサイズを変更したりするなど、多くの Web アプリケーションで一般的な操作です。このインタラクションの最も基本的な UI 部分は、ドラッグ可能な要素とターゲット要素としてのコンテナです。 Vue.js では、ディレクティブとイベント ハンドラーを使用してドラッグ アンド ドロップを実装します。

最初のステップは、Vue インスタンスでのドラッグをトリガーする命令を定義することです。 「v-draggable」ディレクティブは、ドラッグ可能な要素にバインドする必要があります。このディレクティブは、Vue カスタム ディレクティブ API を使用してグローバルまたはローカル コンポーネントとして登録されます。

Vue.directive('draggable', {
binding(el, binding, vnode) {

  let xOffset = 0;
  let yOffset = 0;

  const handleMouseDown = (event) => {
      if (!event.target.classList.contains('drag-handle')) {
          return;
      }

      xOffset = event.clientX;
      yOffset = event.clientY;

      document.addEventListener('mousemove', handleMouseMove);
      document.addEventListener('mouseup', handleMouseUp);
  };

  const handleMouseMove = (event) => {
      const currentX = event.clientX;
      const currentY = event.clientY;

      const dx = currentX - xOffset;
      const dy = currentY - yOffset;

      const newWidth = el.offsetWidth + dx;

      vnode.context[binding.expression] = newWidth;
  };

  const handleMouseUp = () => {
      document.removeEventListener('mousemove', handleMouseMove);
      document.removeEventListener('mouseup', handleMouseUp);
  };

  el.querySelector('.drag-handle').addEventListener('mousedown', handleMouseDown);
ログイン後にコピー

}
});

ディレクティブ内では、マウスダウンイベント(mousedown)を定義します。イベントをディレクティブのバインディング要素 (el) にバインドします。イベントが発生した後、ドラッグ中に要素の新しい位置を計算できるように、要素に対する相対的なマウス オフセットを記録します。次に、mousemove イベントでオフセットを計算し、新しい幅を計算して、それを Vue インスタンスにバインドします。

最後に、マウス リリース イベント (mouseup) をドキュメント オブジェクトにバインドします。これにより、ユーザーがドラッグ領域を離れた後もマウス リリース イベントが検出され、マウス移動イベントとマウス リリース イベントがクリアされます。リスナー。

次に、「v-draggable」ディレクティブを使用して、ドラッグ要素を Vue コンポーネントの data プロパティにバインドします。


ドラッグミー


Vue.component('resizable', {
template: `

<div class="resizable">
  <div class="wrapper">
    <div class="panel-a">
      <div v-draggable="width" class="drag-area">
        <div class="drag-handle"></div>
      </div>
    </div>
    <div class="panel-b" :style="{ width: width + 'px' }"></div>
  </div>
</div>
ログイン後にコピー

`,
data() {

return {
  width: 400,
};
ログイン後にコピー

},
});

この例では、React コンポーネント「Resizable」を作成します。これは、ドラッグ可能な領域とコンテナーで構成されます。 v-draggable ディレクティブを使用してドラッグ要素を幅の値にバインドし、要素はクラス「drag-area」のコンテナに追加されます。

最後に、コンポーネントを DOM にレンダリングします。

new Vue({
el: '#app',
});

このようにして、Vue.js を使用してマウスのドラッグ アンド ドロップを実装し、ドラッグされた要素の幅。 Vue.js は柔軟性と拡張性に優れているため、この種のインタラクションの開発が非常に簡単になります。

以上がVue はマウス ドラッグ コントロールの幅を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート