jQuery UI の Draggable プラグインを使った、ドラッグして移動できるボックスの、移動範囲を設定する方法。
親要素内だけ移動できるようにするには、containment オプションに、parent を指定する。
「#jquery-ui-draggable-wrap」のように特定の要素の id を指定することもできる。
さらに、実装例(サンプル)では、scroll オプションに、false を指定し、ドラッグ移動中に、スクロールできないようにしてある。
実装例(サンプル)
実装例の動作について
「ドラッグして特定要素内だけ移動できるボックス。」と書いてあるボックスを、ドラッグして、移動させることができる。移動できるのは、破線で示した要素内だけ。
実装例のソースコード
読み込み
読み込み方は、2種類ある。パスは、それぞれ、アップロードした場所を指定する。
まとめて読み込む場合
<link rel="stylesheet" href="themes/base/jquery.ui.all.css">
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery-ui-1.8.12.custom.min.js"></script>
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery-ui-1.8.12.custom.min.js"></script>
個別に読み込む場合
<link rel="stylesheet" href="themes/base/jquery.ui.all.css">
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery.ui.core.js"></script>
<script type="text/javascript" src="ui/jquery.ui.widget.js"></script>
<script type="text/javascript" src="ui/jquery.ui.mouse.js"></script>
<script type="text/javascript" src="ui/jquery.ui.draggable.js"></script>
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery.ui.core.js"></script>
<script type="text/javascript" src="ui/jquery.ui.widget.js"></script>
<script type="text/javascript" src="ui/jquery.ui.mouse.js"></script>
<script type="text/javascript" src="ui/jquery.ui.draggable.js"></script>
JavaScript
親要素を指定する場合
<script>
<!--
jQuery( function() {
jQuery( '#jquery-ui-draggable' ) . draggable( {
containment: 'parent',
scroll: false,
} );
} );
// -->
</script>
<!--
jQuery( function() {
jQuery( '#jquery-ui-draggable' ) . draggable( {
containment: 'parent',
scroll: false,
} );
} );
// -->
</script>
id で指定する場合
<script>
<!--
jQuery( function() {
jQuery( '#jquery-ui-draggable' ) . draggable( {
containment: '#jquery-ui-draggable-wrap',
scroll: false,
} );
} );
// -->
</script>
<!--
jQuery( function() {
jQuery( '#jquery-ui-draggable' ) . draggable( {
containment: '#jquery-ui-draggable-wrap',
scroll: false,
} );
} );
// -->
</script>
CSS
<style>
<!--
#jquery-ui-draggable-wrap {
width: 500px;
height: 300px;
padding: 5px;
margin: 0;
border-style: dashed;
border-radius: 10px;
}
#jquery-ui-draggable {
width: 100px;
height: 100px;
padding: 30px;
margin: 0;
border-radius: 10px;
font-size: 13px;
}
-->
</style>
<!--
#jquery-ui-draggable-wrap {
width: 500px;
height: 300px;
padding: 5px;
margin: 0;
border-style: dashed;
border-radius: 10px;
}
#jquery-ui-draggable {
width: 100px;
height: 100px;
padding: 30px;
margin: 0;
border-radius: 10px;
font-size: 13px;
}
-->
</style>
HTML
<div id="jquery-ui-draggable-wrap" class="ui-widget-content">
<div id="jquery-ui-draggable" class="ui-widget-content">
<p>ドラッグして<br />特定要素内だけ<br />移動できる<br />ボックス。</p>
</div>
</div>
<div id="jquery-ui-draggable" class="ui-widget-content">
<p>ドラッグして<br />特定要素内だけ<br />移動できる<br />ボックス。</p>
</div>
</div>