ボタンクリック後に再描画できるjqueryグリッドがあります。これはThe Odin ProjectのためのEtch-a-Sketchプロジェクトのためのものです。再描画後にjQuery .mousenterが機能しない
コードは初めて動作し、グリッドのサイズを選択してから.mouseenterを描画することができます。ただし、ボタンをクリックしてリセットすると、描画ができなくなります。私が間違っていることを確認していない。
私はhttps://jsfiddle.net/davidtaylorjr/cLcbxmnb/14/
HTMLでのプロジェクトのためにjsfiddleを持っている:
<div class="grid_controls">
<button class="clear button">Clear and Redraw</button>
</div>
<div class="container"></div>
CSS:
.grid_controls {
text-align: center;
}
.button {
position: absolute;
top: 50%;
}
.box {
margin:0;
border:1px solid lightblue;
box-sizing:border-box;
float:left;
}
.container{
padding:5px;
}
/*=================
General
=================*/
body {
background: white;
}
/*=================
Sketchpad Holder
=================*/
.container {
width: 500px;
height: 400px;
background-color: none;
overflow: hidden;
margin: auto;
position: relative;
top: 20px;
}
.box {
background: white;
position: relative;
}
.clear {
position: relative;
margin: auto;
text-align: center;
}
.box.black {
background-color: #000;
}
Javascriptを:
$(function(){
//Invoke original function
drawBoxes();
//Draw .box divs
function drawBoxes(){
var gridWidthInBoxes = prompt("Width of grid in boxes?");
//Remove boxes and redraw
$('.box').remove();
for(var i = 0; i < (gridWidthInBoxes * gridWidthInBoxes) ; i++){
$(".container").append("<div class='box'></div>");
}
//Restyle boxes after they have been drawn
restyle(gridWidthInBoxes);
}
//Style .box divs with appropriate width
function restyle(numberofBoxes){
//Set width and height css value for '.box' divs
$('.box').css('width', (100/numberofBoxes)+'%');
$('.box').css('height', (100/numberofBoxes)+'%');
}
//Button event handler
$("button").on('click', function(){
drawBoxes();
});
//Hover to draw boxes
$(".box").mouseenter(function() {
$(this).addClass('black');
});
})();
、ありがとう! – davidtaylorjr