Как добавить <li>в существующий <ul>? - PullRequest
528 голосов
/ 17 июля 2009

У меня есть код, который выглядит так:

<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?

Ответы [ 12 ]

783 голосов
/ 17 июля 2009

Это будет сделано:

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

Две вещи:

  • Вы можете просто добавить <li> к самому <ul>.
  • Вам нужно использовать кавычки противоположного типа, чем те, которые вы используете в своем HTML. Так как вы используете двойные кавычки в своих атрибутах, окружите код одинарными кавычками.
509 голосов
/ 09 ноября 2011

Вы также можете сделать это более «объектным способом» и все еще легко читаемым:

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

Тогда вам не нужно бороться с кавычками, но вы должны следить за фигурными скобками:)

51 голосов
/ 18 января 2012

Как насчет использования "after" вместо "append".

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

". After ()" может вставлять содержимое, указанное параметром, после каждого элемента в наборе соответствующих элементов.

44 голосов
/ 07 марта 2014

Если вы просто добавляете текст в этом li, вы можете использовать:

 $("#ul").append($("<li>").text("Some Text."));
19 голосов
/ 30 сентября 2014

jQuery поставляется со следующими параметрами, которые могут удовлетворить ваши потребности в этом случае:

append используется для добавления элемента в конец родительского элемента div, указанного в селекторе:

$('ul.tabs').append('<li>An element</li>');

prepend используется для добавления элемента в начало / начало родительского элемента div, указанного в селекторе:

$('ul.tabs').prepend('<li>An element</li>');

insertAfter позволяет вам вставить элемент вашего выбора после следующего элемента, который вы укажете. Созданный вами элемент будет помещен в DOM после указанного тега закрытия селектора:

$('<li>An element</li>').insertAfter('ul.tabs>li:last');
will result in:
<li><a href="/user/edit"><span class="tab">Edit</span></a></li>
<li>An element</li>

insertBefore сделает противоположное вышеперечисленному:

$('<li>An element</li>').insertBefore('ul.tabs>li:last');
will result in:
<li>An element</li>
<li><a href="/user/edit"><span class="tab">Edit</span></a></li>
14 голосов
/ 17 июля 2009

Вы должны добавить в контейнер, а не последний элемент:

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

Функция append () , вероятно, должна была быть вызвана add () в jQuery, потому что она иногда сбивает людей с толку. Можно подумать, что он добавляет что-то после данного элемента, в то время как на самом деле добавляет к элементу.

7 голосов
/ 17 июля 2009

вместо

$("#header ul li:last")

попробовать

$("#header ul")
6 голосов
/ 02 февраля 2012
$("#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);

Удачного кодирования:)

6 голосов
/ 17 июля 2009
$("#content ul").append('<li><a href="/user/messages"><span class="tab">Message Center</span></a></li>');
3 голосов
/ 25 мая 2016

Это самый короткий способ сделать это

list.push($('<li>', {text: blocks[i] }));
$('ul').append(list);

Где блоки в массиве. и вам нужно перебрать массив.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...