Динамическое добавление <li /> в <ul /> в jquery mobile

Я пытаюсь добавить элементы списка в неупорядоченные списки в jquery mobile, но кажется, что форматирование создается неправильно.

<ul data-role="listview" data-theme="c" data-dividertheme="b">
                    <li data-role="list-divider">
                        Title Divider
                    </li>
                    <li>
                        <a href="test.html" data-transition="slide">List item 1</a>
                    </li>

 </ul>

Автор сценария:

$('ul').append('<li><a>hello</a></li>');

По какой-то причине динамически генерируемый li не отображается так же, как статически созданный. Кто-нибудь знает почему и как я могу сделать это так же?

5 ответов

Решение

Попробуй это:

$('ul').append($('<li/>', {    //here appending `<li>`
    'data-role': "list-divider"
}).append($('<a/>', {    //here appending `<a>` into `<li>`
    'href': 'test.html',
    'data-transition': 'slide',
    'text': 'hello'
})));

$('ul').listview('refresh');

Ответы оказались немного грязными...

$('ul').append('<li><a>hello</a></li>'); Это нормально, но нужно обновить просмотр списка, поэтому все, что вам нужно, это:

$('ul').append('<li><a>hello</a></li>').listview('refresh');

И если вы хотите изменить атрибуты UL, вам, возможно, придется вызвать.trigger('create') для включающего div. это гарантирует, что UL будет создан снова со сбросом свойств.

Вам нужно будет добавить класс в тег списка

$('<ul>').append( $('<li>').attr('class','ui-li ui-li-static ui-btn-up-c ui-li-last').append('hello'))  ;

JQuery mobile автоматически добавляет класс к элементам списка, что можно увидеть, если вы запустите свою страницу в Firefox и отладите ее с помощью Firebug. Выберите класс, который был применен, и добавьте его в динамически генерируемый тег li.

Другие вопросы по тегам