【发布时间】:2019-05-20 23:14:22
【问题描述】:
我正在尝试使用 ajax 填充我的 jquery 移动列表视图,以通过使用 json 中的数据执行 php Mysql 查询来获取我的电影标题列表。 我成功地以正确的 json 格式获得了数据,但是在我的 javascript 中,我得到了在线错误.... li.appendChild("a")
HTML
<div data-role="main" class="ui-content">
<ul data-role="listview" id="list" >
</ul >
</div>
getcatagories2_mobile.php
<?php
include("includes/connection.php");
$q="Comedy";
$resultActor = mysqli_query($con,"SELECT id,title, plot,catagory,release_date,rated FROM ".TBL_DATA." WHERE catagory LIKE '%".$q."%' ORDER BY title ");
$x= array();
while($rowMovie = mysqli_fetch_array($resultActor)) {
$x[]= array("Category" => $rowMovie['title']);
}
$jsonarray=json_encode($x);
echo $jsonarray;
?>
successful sample JSON format output
[{"Category":"22 Jump Street"},{"Category":"27 Dresses"}]
my called javascript function using ajax...
var xhr = new XMLHttpRequest();
xhr.open("GET", "getcatagories2_mobile.php", true);
xhr.onreadystatechange = function()
{
if (xhr.readyState == 4 && xhr.status == 200)
{
var list = document.getElementById("list");
var data= xhr.responseText;
var vec= JSON.parse(data);
vec.forEach(
function(ob)
{
var li = document.createElement("li");
var a = document.createElement("a");
var text = document.createTextNode("ob.Category");
a.appendChild(text);
a.setAttribute("href","#");
li.appendChild("a");
list.appendChild("li");
}
);
$('#list').listview('refresh');
}
}
xhr.send();
};
当我使用 google debug 时,我在 line-> li.appendChild("a") 上遇到错误,当我将鼠标悬停在 var vec= JSON.parse(data) 上时,数据显示正确。
我想要实现的只是让我的 jquery mobile 像这样执行
<div data-role="main" class="ui-content">
<ul data-role="listview" id="list" >
<li><a href="#">22 Jump Street</a></li>
<li><a href="#">27 Dresses</a></li>
</ul >
</div>
【问题讨论】:
-
通过在循环外附加到 DOM 会快很多。只需将列表项连接为文本,然后一次性执行
$('#list').append(html).listview('refresh');之类的操作。 -
感谢您的回复,但我不明白“附加到循环外的 DOM。只需将您的列表项连接为文本”我不是专家 :(
-
好的,我会努力解决这个问题的,谢谢
标签: javascript php jquery-mobile