2012-10-16 23 views
0

我有一个名为CONTEST使用下面的值在数据库上字段名:JS不允许破折号( - );有任何想法吗?

50 - DE - HOUSE 5 -D 
47 - SHERIFF - M 

还有那些几行。

fieldname是一个文本字段。

我用下面的JavaScript来尝试在表格中显示这些值:

//Create list of available contest to display. 
function CreateResultSet(featureSet) { 
    demVoteCount = 0; 
    repVoteCount = 0; 
    otherVoteCount = 0; 
    RemoveChildren(dojo.byId("race")); 
    resultsDataGroup = new Object(); 
    var controlIndex = 0; 
    if (featureSet.length == 0) { 
     return; 
    } 
    else { 
     for (var i = 0; i < featureSet.length; i++) { 
      if (!resultsDataGroup[featureSet[i].attributes.CONTEST]) { 
       resultsDataGroup[featureSet[i].attributes.CONTEST] = new Array(); 
       var divRaceData = document.createElement("div"); 
       divRaceData.className = "divData"; 
       divRaceData.id = "divRaceName" + (controlIndex); 
       divRaceData.innerHTML = featureSet[i].attributes.CONTEST; 
       divRaceData.setAttribute("controlIndex", controlIndex); 
       divRaceData.onclick = function() { DisplayChart(this); }; 
       dojo.byId("race").appendChild(divRaceData); 
       controlIndex++; 
      } 

      if (featureSet[i].attributes.PARTY == "DEM") { 
       demVoteCount += featureSet[i].attributes.VOTES; 
      } 
      else if (featureSet[i].attributes.PARTY == "REP") { 
       repVoteCount += featureSet[i].attributes.VOTES; 
      } 
      else { 
       otherVoteCount += featureSet[i].attributes.VOTES; 
      } 
      resultsDataGroup[featureSet[i].attributes.CONTEST].push({ ContestName: featureSet[i].attributes.CONTEST, CandidateName: featureSet[i].attributes.CANDIDATE, VoteTotal: featureSet[i].attributes.VOTES, Party: featureSet[i].attributes.PARTY }); 
     } 
     dojo.byId("race").scrollTop = 0; 
     currentRaceIndex = 0; 
     DisplayChart(dojo.byId("race").childNodes[0]); 
     dojo.byId('divSelectedGeometry').innerHTML = dojo.query(".divSelectedGeo", dojo.byId('geometry'))[0].innerHTML + " - "; 
    } 
} 

当我运行代码,我得到“较量”未找到。

但是,如果我删除破折号,结果正确显示,但破折号需要在那里。

任何想法如何修改这样的字段名叫CONTEST来解决破折号?

对不起,如果这是措辞不佳。

非常感谢

+0

你可以运行萤火虫或Chrome开发人员工具,并在告诉我们哪条线发生错误。这可以帮助你找到问题的原因 – kabaros

+0

@kabaros,它在这一行: divRaceData.innerHTML = featureSet [i] .attributes.CONTEST; –

+2

提供属性'.CONTEST'存在并且是一个合法的JavaScript标识符,代码不应该失败。错误消息表明'.CONTEST'不存在,所以我只能假设问题出在代码之外的某处;即构成'featureSet'的任何地方。 –

回答

0

的SQL有破折号的办法就是把它放在你正在做的括号,破折号所以不应该破坏你的SQL。

我唯一的解释是,你的对象从服务器端来的时候缺少一些值。

你可以改变线在发生错误时添加一些额外的检查,以便:

divRaceData.innerHTML = (featureSet[i] && featureSet[i].attributes && featureSet[i].attributes.CONTEST)?featureSet[i].attributes.CONTEST : "VALUE MISSING"; 

如果你得到“VALUE失踪”那么有什么错在你的服务器端代码和一个或多个对象没有你期望的层次结构。

而像甜菜根在评论中说,这是一个非常不好的做法,注入SQL这样的,所以即使你继承了应用程序了,这是值得改变这种

+0

谢谢@卡巴罗斯。我按照你的建议做了,但我没有收到VALUE MISSING消息。我确实有“无法找到竞赛”之类的东西,我知道这存在。 –

+0

尝试更改为featureSet [i] .attributes [CONTEST] ..并且还打开了firebug或控制台,并添加一行:console.log(featureSet [i] .attributes.CONTEST);在你的代码之前这个调用,看看你得到的对象,如果它形成了你期望的方式 – kabaros

+0

我使用了萤火虫。在你做出最新的改变后,它仍然显示相同的错误 –