我有一个要求,我根据JSON响应动态创建单选按钮。到目前为止,我在Chrome和Firefox中所做的工作,但在Object doesn't support this property or method
行上提供了if(subItem[1].indexOf(",") >= 0)
我的代码
$("#sList").live("change", function(){
var currentService=this.value;
var c1Svc=[];
var c2Svc=[];
if(absP.length==2)
{
$.each(compareServiceData,function(i,item){
if(currentService==item[0])
{
var configCount=0;
$.each(item[1],function(j,subItem){
var temp=subItem[1];
/*The JSON response contains List of Lists, so here if it contains a list it will be separated by "," so split it and store in a array, else directly store in a array*/
if(subItem[1].indexOf(",") >= 0)
{
var tList=temp.split(",");
$.each(tList,function(k,val){
if(configCount==0)
{
c1Svc.push(val);
}
else
{
c2Svc.push(val);
}
});
}
else
{
if(configCount==0)
{
c1Svc.push(subItem[1]);
}
else
{
c2Svc.push(subItem[1]);
}
}
configCount++;
});
}
});
if ($("#customServiceListing").length == 0)
{
$("#compareContent").append('<table id="customServiceListing" align="center" width="90%" class="csm-table" border="1"><tbody><tr><td><form id="c1Service"></form></td><td><form id="c2Service"></form></td></tr></tbody></table>');
}
else
{
$('#c1Service').empty();
$('#c2Service').empty();
}
}
else
{
$("#compareContent").append('<table align="center" width="90%" class="csm-table" border="1"><tbody><tr><td><form><select id="c1Service"></select></form></td><td><select id="c2Service"></select></td><td><select id="c3Service"></select></td></tr></tbody></table>');
}
/*adding service radios to config1*/
$.each(c1Svc,function(i,item){
$("#c1Service").append('<input type="radio" name="customConfig1ServiceNames" id="'+item+'" value="'+i+1+'"/>'+item);
});
if(c1Svc.length>1)
$("#c1Service").append('<br/>');
/*adding service radios to config2*/
$.each(c2Svc,function(i,item){
$("#c2Service").append('<input type="radio" name="customConfig2ServiceNames" id="'+item+'" value="'+i+1+'"/>'+item);
});
if(c2Svc.length>1)
$("#c2Service").append('<br/>');
});
更新
Here是IE8不支持的各种功能代码的列表
更新
这里有什么问题,因为它给我的每个值-1
我使用的是Sudhir提供的代码
alert(subItem[1].indexOf(",")+", "+subItem[1]);
截图
更新
在这里得到它,var temp=subItem[1].toString();
是问题,将其转换为String工作。
答案 0 :(得分:16)
IE版本&lt; 9没有indexOf
,因此您可以添加自己的:
if (!Array.prototype.indexOf) {
Array.prototype.indexOf = function (elt /*, from*/) {
var len = this.length >>> 0;
var from = Number(arguments[1]) || 0;
from = (from < 0) ? Math.ceil(from) : Math.floor(from);
if (from < 0) from += len;
for (; from < len; from++) {
if (from in this && this[from] === elt) return from;
}
return -1;
};
}
var subItem = [];
subItem[1]="CSMTestPWXListinerService,CSMTestPWXListinerService_ManualyAdded";
console.log(subItem[1].indexOf(","));
//returns 25
答案 1 :(得分:1)
根据http://msdn.microsoft.com/en-us/library/ie/53xtt423(v=vs.94).aspx
MS已经表示它也支持索引()到IE8!
答案 2 :(得分:0)
如果你这样做会怎么样?:
if(temp.indexOf(",") >= 0)
我知道我遇到的情况是,当从数组引用而不是从该数组位置的内容创建的变量时,它似乎无法理解对象类型是什么。这种情况没有意义,但我之前已将其用作解决方法。