我有这样的代码:

<div id="header">
    <ul class="tabs">
        <li><a href="/user/view"><span class="tab">Profile</span></a></li>
        <li><a href="/user/edit"><span class="tab">Edit</span></a></li>
    </ul>
</div>

我想使用jQuery添加以下到列表:

<li><a href="/user/messages"><span class="tab">Message Center</span></a></li>

我试了一下:

$("#content ul li:last").append("<li><a href="/user/messages"><span class="tab">Message Center</span></a></li>");

但是这会在最后一个li中(就在结束标记之前)添加新的li,而不是在最后一个li之后。加上这个li的最好方法是什么?


当前回答

Use:

// Creating and adding an element to the page at the same time.
$("ul").append("<li>list item</li>");

其他回答

$("#content ul").append('<li><a href="/user/messages"><span class="tab">Message Center</span></a></li>');

Use:

$("#content ul").append('<li><a href="/user/messages"><span class="tab">Message Center</span></a></li>');

这里是一些关于代码可读性的反馈(无耻的博客)。 http://coderob.wordpress.com/2012/02/02/code-readability

考虑将新元素的声明与将它们添加到UL的操作分开。它看起来是这样的:

var tabSpan = $('<span/>', {
    html: 'Message Center'
});
var messageCenterAnchor = $('<a/>', {
    href='/user/messages',
    html: tabSpan
});
var newListItem = $('<li/>', {
    html: messageCenterAnchor,
    "id": "myIDGoesHere"
});    // NOTE: you have to put quotes around "id" for IE..

$("content ul").append(newListItem);

Use:

// Creating and adding an element to the page at the same time.
$("ul").append("<li>list item</li>");

这是另一个

$("#header ul li").last().html('<li> Menu 5 </li>');

只是添加到这个线程-如果你正在移动一个现有的项目,你将需要使用克隆,然后true/false是否克隆/深度克隆事件以及(https://api.jquery.com/clone/)。

例子: $(" #内容ul) .append ($ (' .existing_li ') .clone(真));