59

当我单击 ID 为 #add 的按钮时,我想向现有 div 添加文本。但这不起作用。

这是我的代码:

$(function () {
  $('#Add').click(function () {
    $('<p>Text</p>').appendTo('#Content');
  });
}); 
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
 <div id="Content">
    <button id="Add">Add</button>
 </div>

我希望你能帮助我。

4

6 回答 6

62

您需要定义按钮文本并为该按钮提供有效的 HTML。我还建议使用.on按钮的点击处理程序

$(function () {
  $('#Add').on('click', function () {
    $('<p>Text</p>').appendTo('#Content');
  });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div id="Content">
    <button id="Add">Add Text</button>
</div>

此外,我会确保 jquery 位于页面底部,就在结束</body>标记之前。这样做会让你不必把整个东西都包起来,$(function但我仍然会这样做。在页面末尾加载您的 javascript 可以使页面的其余部分加载,以防您的 javascript 在某处变慢。

于 2013-03-22T22:51:26.193 回答
11

运行示例:

//If you want add the element before the actual content, use before()
$(function () {
  $('#AddBefore').click(function () {
    $('#Content').before('<p>Text before the button</p>');
  });
});

//If you want add the element after the actual content, use after()
$(function () {
  $('#AddAfter').click(function () {
    $('#Content').after('<p>Text after the button</p>');
  });
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>

<div id="Content">
<button id="AddBefore">Add before</button>
<button id="AddAfter">Add after</button>
</div>

于 2013-03-22T22:51:22.270 回答
5

您的 html 无效button不是空标记。尝试

<div id="Content">
   <button id="Add">Add</button>
</div> 
于 2013-03-22T22:49:19.077 回答
0

我们可以用更简单的方法来做到这一点,比如在按钮上添加一个函数,然后在单击时调用该函数进行追加。

<div id="Content">
<button id="Add" onclick="append();">Add Text</button>
</div> 
<script type="text/javascript">
function append()
{
$('<p>Text</p>').appendTo('#Content');
}
</script>
于 2016-03-25T10:56:23.340 回答
0

从我这边很容易:-

<html>
<head>
<script
    src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.2/jquery.min.js"></script>
<script>
    $(document).ready(function() {
        $("input").click(function() {
            $('<input type="text" name="name" value="value"/>').appendTo('#testdiv');
        });

    });
</script>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
    <div id="testdiv"></div>
    <input type="button" value="Add" />
</body>
</html>
于 2016-05-27T17:24:08.683 回答
0

$(function () {
  $('#Add').click(function () {
    $('<p>Text</p>').appendTo('#Content');
  });
}); 
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
 <div id="Content">
    <button id="Add">Add<button>
 </div>

于 2018-07-08T10:24:31.017 回答