原生html循环div,javascript – 尝试使用for循环jquery中的inner.HTML生成div

我正在尝试使用以下for循环从JSON对象创建库的缩略图视图.

function GalleryContent(url){

var hr = new XMLHttpRequest();

var results= document.getElementById("results");

hr.open("POST",url);

hr.setRequestHeader("Content-type","application/x-www-form-urlencoded");

hr.onreadystatechange = function() {

if(hr.readyState == 4 && hr.status == 200) {

var data= $.parseJSON(hr.responseText);

var results = document.getElementById("results");

results.innerHTML = "";

for (var obj in data){

results.innerHTML += "

"+data[obj].Num+data[obj].title+"
";

results.innerHTML += "

Num:"+data[obj].Num+ "
";

results.innerHTML += "

Title:"+data[obj].title+ "
";

results.innerHTML += "

Price: "+data[obj].Price+ "
";

}

}

}

这工作正常,但我发现任何我添加的div仅适用于当前附加内容,我需要的是将这4个结果封装在div中,这样我就可以使用内容并在显示后设置样式在页面上.

我的新问题是在哪里以及如何添加第二个循环,它只将一组信息放入div中,然后可以将其附加到我的.getElementByID中的结果div

提前感谢您的任何指导.

解决方法:

如果我正确理解您的问题,您不需要额外的循环.

如果你想在#results中包含整个事物,你可以打开和关闭你的for循环之外的div.根据您的注释,您还需要将要写入的内容保存到变量中,而不是连续设置innerHTML,否则浏览器将尝试自动修复未关闭的HTML元素.最后完成这一切.

content = "";

content += "

";

for (var obj in data) {

...

}

content += "

";

results.innerHTML = content;

如果要包围从JSON响应返回的每个对象,可以在for循环中但在项目之前和之后进行.

content = "";

for (var obj in data) {

content += "

";

}

content += "

";
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值