我在火狐中得到了一个关于getAttribute不是一个函数的错误。下面是标有错误行的代码。
var nodeList = document.getElementsByTagName("input");
for(item in nodeList){
try{
if(nodeList[item].getAttribute("type") == "file"){
//ERROR HERE///->var id = nodeList[item].getAttribute("id");
var fileSelector = document.getElementById(id);
document.getElementById(id).addEventListener("change",function(e){
if(e){
e.preventDefault();
}
if (fileSelector.files) {
window.file = fileSelector.files[0];
} else {
window.file = fileSelector.value;
}
readData();
});
}
}catch(e){}
}发布于 2013-01-30 00:45:28
试着这样做:
var nodeList = document.getElementsByTagName("input");
var max = nodeList.length;
for(var i=0; i<max ; i++){
try{
if(nodeList[i].getAttribute("type") == "file"){
//ERROR HERE///->var id = nodeList[item].getAttribute("id");
var fileSelector = document.getElementById(id);
document.getElementById(id).addEventListener("change",function(e){
if(e){
e.preventDefault();
}
if (fileSelector.files) {
window.file = fileSelector.files[0];
} else {
window.file = fileSelector.value;
}
readData();
});
}
}catch(e){}
}发布于 2013-01-30 00:45:29
可能nodeList[item]不是一个节点。使用for循环而不是for..in
var i, len = nodeList.length;
for(i=0; i<len; i += 1){
try {
if(nodeList[i].getAttribute("type") == "file"){
// ...发布于 2013-01-30 00:52:06
有关说明,请参阅JSFiddle
for (item in nodeList)给出0,1和2作为数组索引,这是可以的。
但是它提供了更多的属性length、item和namedItem,这些属性不是DOM元素,也没有getAttribute()函数。
因此,正如其他人已经建议的那样,使用普通的for循环。
https://stackoverflow.com/questions/14587811
复制相似问题