请考虑这条绳子:
['2012-2','2012-3','2012-4','2013-1','2013-2','2013-3','2013-4','2014-1']我从一个web方法中返回这个字符串,我想循环这个值,并编写如下:
var tr = '<tr><td>Title</td>';
$.each(arrPeriods, function (index, value) {
tr += '<td>' + value + '</td>';
});
tr += '</tr>';我得到了一个错误:
JavaScript运行时错误:“in”的操作数无效:预期的对象
我认为问题在于,我应该将字符串转换为数组,但我不知道如何做到这一点。请帮我解决我的问题。
发布于 2018-09-25 11:16:18
必须将所有"'"替换为"\"",然后可以使用JSON.parse()将字符串转换为数组。就像这样:
var answer = "['2012-2','2012-3','2012-4','2013-1','2013-2','2013-3','2013-4','2014-1']";
answer = answer.split("'").join("\"");
var arrPeriods = JSON.parse(answer);
var tr = $('<tr><td>Title</td></tr>');
$.each(arrPeriods, function(index, value) {
tr.append('<td>' + value + '</td>');
});
$('table').append(tr);发布于 2018-09-25 11:12:28
在将字符串转换为数组之后,必须使用jQuery方法.append()来添加td。
注意:如果可能的话,我建议从后端返回一个数组,这样会更有效。此解决方案目前只是暂时修复。
var arrPeriods = "['2012-2', '2012-3', '2012-4', '2013-1', '2013-2', '2013-3', '2013-4', '2014-1']";
var myArray = arrPeriods.replace(/\[|\]|'/g, '').split(',');
var tr = $('<tr><td>Title</td></tr>');
$.each(myArray, function(index, value) {
tr.append('<td>' + value + '</td>');
});
$('table').append(tr);<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table border=1></table>
发布于 2018-09-25 12:03:37
见评论。
var arrPeriods = "['2012-2', '2012-3', '2012-4', '2013-1', '2013-2', '2013-3', '2013-4', '2014-1']";
arrPeriods = arrPeriods.replace(/'/g, '"'); // Clean the string into an acceptable JSON string
arrPeriods = JSON.parse(arrPeriods); // Parse the JSON string
var $tr = $('<tr><td>Title</td></tr>'); // Create the row
var $table = $('<table></table>')
.append($tr);
// No need to use jQuery's .each
arrPeriods.forEach(function (date) {
$tr.append('<td>' + date + '</td>');
});
$('body').append($table);<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
https://stackoverflow.com/questions/52496728
复制相似问题