ondragoverイベントとは、ドラッグ状態のマウスのポインタ(カーソル)が、ドロップ可能な要素上に重なってる時のイベント。
構文
HTML
<element ondragover="イベントハンドラ">
例
div要素
<div ondragover="イベントハンドラ">div要素</div>
p要素
<p ondragover="イベントハンドラ">p要素</p>
ul要素
<ul ondragover="イベントハンドラ">
<li>リスト項目</li>
</ul>
<li>リスト項目</li>
</ul>
JavaScript
object.ondragover = function(){ イベントハンドラ };
サンプル1
HTMLドキュメント上でイベントハンドラを登録するサンプル。
2
1
カウントアップ:0
サンプル1の動作について
- 「2」をドラッグし、背景色が薄い青色である領域にドロップすると、領域内の数値に「2」を掛け合わせる。
- 「2」をドラッグし、背景色が薄い青色である領域上にある間、「カウントアップ:」の右横の数値に1を加算し続ける。
- FireFox、Chrome、IE11にて動作確認。
サンプル1のソースコード
JavaScript
<script type="text/javascript">
function sampleAOnDragStart( $event ){
$event.dataTransfer.setData( "Text", $event.target.innerHTML );
};
function sampleADrop( $event, $this ){
var $data = $event.dataTransfer.getData( "Text" );
$this.innerHTML = $this.innerHTML * $data;
};
var $countA = 0;
function sampleACountUp() {
document.getElementById( "sampleOutputA" ).innerHTML = ++$countA;
}
</script>
function sampleAOnDragStart( $event ){
$event.dataTransfer.setData( "Text", $event.target.innerHTML );
};
function sampleADrop( $event, $this ){
var $data = $event.dataTransfer.getData( "Text" );
$this.innerHTML = $this.innerHTML * $data;
};
var $countA = 0;
function sampleACountUp() {
document.getElementById( "sampleOutputA" ).innerHTML = ++$countA;
}
</script>
HTML
<p>
<span id="sampleDragA" draggable="true" ondragstart="sampleAOnDragStart( event );">2</span>
</p>
<div
id="sampleDropA"
ondrop="sampleADrop( event, this );
event.preventDefault();"
ondragenter="event.preventDefault();"
ondragover="sampleACountUp(); event.preventDefault();"
>
1
</div>
<p>
カウントアップ:<span id="sampleOutputA" style="margin-left: 10px;">0</span>
</p>
<span id="sampleDragA" draggable="true" ondragstart="sampleAOnDragStart( event );">2</span>
</p>
<div
id="sampleDropA"
ondrop="sampleADrop( event, this );
event.preventDefault();"
ondragenter="event.preventDefault();"
ondragover="sampleACountUp(); event.preventDefault();"
>
1
</div>
<p>
カウントアップ:<span id="sampleOutputA" style="margin-left: 10px;">0</span>
</p>
CSS
<style>
#sampleDragA {
padding: 0 5px;
border: 1px solid gray;
background-color: yellow;
cursor: pointer;
}
#sampleDropA {
width: 500px;
padding: 20px 0;
background-color: lightblue;
text-align: center;
}
</style>
#sampleDragA {
padding: 0 5px;
border: 1px solid gray;
background-color: yellow;
cursor: pointer;
}
#sampleDropA {
width: 500px;
padding: 20px 0;
background-color: lightblue;
text-align: center;
}
</style>
サンプル2
JavaScript上で動的にイベントハンドラを登録するサンプル。
2
1
カウントアップ:0
サンプル2の動作について
- 「2」をドラッグし、背景色が薄い青色である領域にドロップすると、領域内の数値に「2」を掛け合わせる。
- 「2」をドラッグし、背景色が薄い青色である領域上にある間、「カウントアップ:」の右横の数値に1を加算し続ける。
- FireFox、Chrome、IE11にて動作確認。
サンプル2のソースコード
JavaScript
<script type="text/javascript">
window.onload = function () {
var $sampleDragB = document.getElementById( "sampleDragB" );
var $sampleDropB = document.getElementById( "sampleDropB" );
$sampleDragB.ondragstart = function( $event ){
$event.dataTransfer.setData( "Text", $event.target.innerHTML );
};
$sampleDropB.ondragenter = function( $event ){
$event.preventDefault();
};
$sampleDropB.ondragover = function( $event ){
sampleBCountUp( $event );
$event.preventDefault();
};
$sampleDropB.ondrop = function( $event ){
$event.preventDefault();
var $data = $event.dataTransfer.getData( "Text" );
this.innerHTML = this.innerHTML * $data;
};
}
var $countB = 0;
function sampleBCountUp( $event ) {
document.getElementById( "sampleOutputB" ).innerHTML = ++$countB;
}
</script>
window.onload = function () {
var $sampleDragB = document.getElementById( "sampleDragB" );
var $sampleDropB = document.getElementById( "sampleDropB" );
$sampleDragB.ondragstart = function( $event ){
$event.dataTransfer.setData( "Text", $event.target.innerHTML );
};
$sampleDropB.ondragenter = function( $event ){
$event.preventDefault();
};
$sampleDropB.ondragover = function( $event ){
sampleBCountUp( $event );
$event.preventDefault();
};
$sampleDropB.ondrop = function( $event ){
$event.preventDefault();
var $data = $event.dataTransfer.getData( "Text" );
this.innerHTML = this.innerHTML * $data;
};
}
var $countB = 0;
function sampleBCountUp( $event ) {
document.getElementById( "sampleOutputB" ).innerHTML = ++$countB;
}
</script>
HTML
<p>
<span id="sampleDragB" draggable="true">2</span>
</p>
<div id="sampleDropB">1</div>
<p>
カウントアップ:<span id="sampleOutputB" style="margin-left: 10px;">0</span>
</p>
<span id="sampleDragB" draggable="true">2</span>
</p>
<div id="sampleDropB">1</div>
<p>
カウントアップ:<span id="sampleOutputB" style="margin-left: 10px;">0</span>
</p>
CSS
<style>
#sampleDragB {
padding: 0 5px;
border: 1px solid gray;
background-color: yellow;
cursor: pointer;
}
#sampleDropB {
width: 500px;
padding: 20px 0;
background-color: lightblue;
text-align: center;
}
</style>
#sampleDragB {
padding: 0 5px;
border: 1px solid gray;
background-color: yellow;
cursor: pointer;
}
#sampleDropB {
width: 500px;
padding: 20px 0;
background-color: lightblue;
text-align: center;
}
</style>