abi*_*964 4 html javascript jquery internet-explorer internet-explorer-8
我有一个要求,我根据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/>');
});
Run Code Online (Sandbox Code Playgroud)
更新
这是IE8不支持的各种功能代码的列表
更新
这里有什么问题,因为它给我的每个值-1我使用的是Sudhir给出的代码
alert(subItem[1].indexOf(",")+", "+subItem[1]);
截图

更新
得到它,var temp=subItem[1].toString();是问题,将其转换为String工作.
Sud*_*oti 16
IE版本<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;
};
}
Run Code Online (Sandbox Code Playgroud)
var subItem = [];
subItem[1]="CSMTestPWXListinerService,CSMTestPWXListinerService_ManualyAdded";
console.log(subItem[1].indexOf(","));
//returns 25
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11357 次 |
| 最近记录: |