ホームページ > ウェブフロントエンド > CSSチュートリアル > CSS Transform Scale を使用して jQuery の正しいドラッグ/サイズ変更動作を実現するにはどうすればよいですか?

CSS Transform Scale を使用して jQuery の正しいドラッグ/サイズ変更動作を実現するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-10-27 08:24:31
オリジナル
482 人が閲覧しました

How to Achieve Correct jQuery Drag/Resize Behavior with CSS Transform Scale?

CSS 変換スケールによる jQuery のドラッグ/サイズ変更の修正

背景

CSS 変換の適用要素を作成し、その子に対して jQuery のドラッグ可能でサイズ変更可能なプラグインを使用すると、マウス カーソルとドラッグまたはサイズ変更された要素との間にずれが生じる可能性があります。これは、要素に適用されるスケール係数が原因です。

jQuery パッチ ソリューション

以前のソリューションでは、jQuery のドラッグ可能およびサイズ変更可能なプラグインにパッチを適用して、マウス オフセットを調整する必要がありました。スケール係数。この方法では、プラグインのソース コードを変更する必要がありました。

代替ソリューション: コールバック ハンドラー

代替ソリューションは、サイズ変更およびドラッグ可能なプラグインによって提供されるコールバック ハンドラーを使用することです。これにより、jQuery にパッチを適用する必要がなくなります。

サイズ変更可能な修正

<br>$(this).resizable({</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">minWidth: -(contentElem.width()) * 10,  
minHeight: -(contentElem.height()) * 10,  
resize: function(event, ui) {

    var changeWidth = ui.size.width - ui.originalSize.width; 
    var newWidth = ui.originalSize.width + changeWidth / zoomScale; 

    var changeHeight = ui.size.height - ui.originalSize.height; 
    var newHeight = ui.originalSize.height + changeHeight / zoomScale; 

    ui.size.width = newWidth;
    ui.size.height = newHeight;

}
ログイン後にコピー

});

サイズ変更ハンドラーで、幅と高さの変化を計算し、ズーム スケールの逆数を適用して新しい幅と高さを調整し、

ドラッグ可能な修正

<br>$(this).draggable({</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">handle: '.drag-handle',
start: function(event, ui) {
    ui.position.left = 0;
    ui.position.top = 0;
},
drag: function(event, ui) {

    var changeLeft = ui.position.left - ui.originalPosition.left; 
    var newLeft = ui.originalPosition.left + changeLeft / (( zoomScale)); 

    var changeTop = ui.position.top - ui.originalPosition.top; 
    var newTop = ui.originalPosition.top + changeTop / zoomScale; 

    ui.position.left = newLeft;
    ui.position.top = newTop;

}
ログイン後にコピー

});

ドラッグ ハンドラーで、左と上の位置の変化を計算し、ズーム スケールの逆数を適用して新しい左と上の位置を調整し、

結論

コールバック ハンドラーを使用したこの代替ソリューションは、CSS がスケールで変換されるときにドラッグ/サイズ変更の動作を修正する非侵襲的な方法を提供します。適用されました。

以上がCSS Transform Scale を使用して jQuery の正しいドラッグ/サイズ変更動作を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
前の記事:ブラウザの互換性とデザインの柔軟性のバランスが最も優れている HTML5 リセット CSS ソリューションはどれですか? 次の記事:CSS を使用して HTML テーブル内のテキストを垂直方向に回転させる方法
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
最新の問題
関連トピック
詳細>
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート