Я пытаюсь перетащить изображение на div. Изображение не перетаскивается на div и дает следующую ошибку
Uncaught TypeError: Failed to execute 'appendChild' on 'Node': parameter 1 is not of type 'Node'.draganddrop.html:20 dropdraganddrop.html:26 ondrop
Код
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>Creativity Dashboard</title>
<!-- Required CSS -->
<link href="css/movingboxes.css" rel="stylesheet">
<link href="css/compare.css" rel="stylesheet">
<!--[if lt IE 9]>
<link href="css/movingboxes-ie.css" rel="stylesheet" media="screen">
<![endif]-->
<!-- Required script -->
<script src="http://code.jquery.com/jquery-1.8.0.min.js"></script>
<script src="js/jquery.movingboxes.js"></script>
<!-- Demo only -->
<link href="demo/demo.css" rel="stylesheet">
<script src="demo/demo.js"></script>
<script>
function allowDrop(ev) {
ev.preventDefault();
}
function drag(ev) {
ev.dataTransfer.setData("text", ev.target.id);
}
function drop(ev) {
ev.preventDefault();
var data = ev.dataTransfer.getData("text");
ev.target.appendChild(document.getElementById(data));
}
</script>
<style>
/* Overall & panel width defined using css in MovingBoxes version 2.2.2+ */
#slider-one {
width: 1003px;
}
#slider-one>li {
width: 150px;
}
</style>
</head>
<body>
<div class="wrapper">
<!-- Slider #1 -->
<ul id="slider-one">
<li><img id="drag1" src="demo/1.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
<li><img id="drag2" src="demo/2.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
<li><img id="drag3" src="demo/3.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
<li><img id="drag5" src="demo/4.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
<li><img id="drag6" src="demo/5.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
<li><img id="drag7" src="demo/6.jpg" draggable="true"
ondragstart="drag(event)" alt="picture" id="astronaut"></li>
<li><img id="drag8" src="demo/7.jpg" draggable="true"
ondragstart="drag(event)" alt="picture"></li>
</ul>
<!-- end Slider #1 -->
<div id="dragAnddrop" ondrop="drop(event)"
ondragover="allowDrop(event)" style="width: 12em; height: 12em">
</div>
</div>
<div>
<div class="left">
<img id="drag" draggable="true" ondragstart="drag(event)"
src="images/startingImage.jpg" style="width: 12em;" alt="picture">
</div>
<div class="middle ">
<img id="image3" src="images/startingImage.jpg" class="image-size"
alt="picture" draggable="true" ondragstart="drag(event)"> <img
src="images/harvest.jpg" class="image-size" alt="picture">
</div>
<div class="right">
<img src="images/startingImage.jpg" style="width: 12em;"
alt="picture">
</div>
</div>
</body>
</html>
javascript
html
MindBrain
источник
источник
document.getElementById
скорее всего возвращает null, проверьте значениеdata
ev.target.appendChild(document.getElementById(data));
но если нет элемента с идентификатором,data
тогдаdocument.getElementById
вернетсяnull
. Такev.target.appendChild(null)
что кинем.Ответы:
На самом деле это простой ответ.
Ваша функция возвращает строку, а не
div
узел.appendChild
может только добавить узел.Например, если вы попытаетесь добавить строку:
Приведенный выше код никогда не будет работать. Что будет работать:
источник
Это может произойти, если вы случайно не перетаскиваете элемент, которому назначен идентификатор (например, вы перетаскиваете окружающий элемент). В этом случае идентификатор пуст, а функция drag () присваивает пустое значение, которое затем передается в drop () и там не работает.
Попробуйте назначить идентификаторы всем вашим элементам, включая tds, div или все, что находится вокруг вашего перетаскиваемого элемента.
источник
В моем случае не было строки, на которую я звонил
appendChild
, объект, который я передавалappendChild
аргументу, был неправильным, это был массив, и я передал объект элемента, поэтому я использовалdivel.appendChild(childel[0])
вместо,divel.appendChild(childel)
и он сработал. Надеюсь, это кому-то поможет.источник
использовать
ondragstart(event)
вместоondrag(event)
источник
Вы также можете использовать
element.insertAdjacentHTML('beforeend', data);
Пожалуйста, прочтите «Вопросы безопасности» на MDN .
источник