1

获取数据后,我使用 JSON 将元素添加到列表中,我执行以下操作:

success: function(data){          
  var list = $('#' + HTMLfieldName[index] + 'Ul');
  $.each(data, function() {
    newLi = document.createElement('li');
    ref = document.createElement('a');
    ref.innerHTML = this.description;
    ref.href = '#' + this.code;
    newLi.appendChild(ref);
   list.append(newLi);
   });          
}

这很好用,但列表中的元素显示为普通 href(蓝色和下划线),而不是 listview 示例中使用的漂亮 CSS。

这是代码在渲染后的样子:

<ul class="levelUl ui-listview ui-listview-inset ui-corner-all ui-shadow" data-role="listview" data-inset="true" name="famUl" id="famUl">
  <li><a href="#2930">Finishing</a></li>
  <li><a href="#2910">Speciality Printing</a></li>
  <li><a href="#2900">Toner</a></li>
</ul>

如果我将该代码粘贴到 HTML 页面中,它看起来很好。

将 CSS 添加到页面后,我是否需要执行某些操作来应用 CSS?

4

1 回答 1

2

您必须在动态添加的列表视图元素上触发标记增强:

$('ul#id').listview('refresh'):

现场示例:http: //jsfiddle.net/Gajotres/LrAyE/

基本上你的代码看起来像这样:

success: function(data){          
    var list = $('#' + HTMLfieldName[index] + 'Ul');
    $.each(data, function() {
        newLi = document.createElement('li');
        ref = document.createElement('a');
        ref.innerHTML = this.description;
        ref.href = '#' + this.code;
        newLi.appendChild(ref);
        list.append(newLi);
    });
    list.listview('refresh');    
}

请记住,您必须.listview('refresh');each循环之后调用。

要了解更多信息,请阅读我的另一篇文章,或在此处找到。

于 2013-03-28T10:28:07.293 回答