2

我有一个站点范围的 JS,它为各种事件创建侦听器,但在某些情况下,我需要调用特定的函数,就像在下面的代码中一样,我需要调用 function call,但它没有被调用。

<html>
<head>
<script>
window.onload = function ()
{    
   var inputs = document.getElementsByTagName("input");
   var len = inputs.length;

   for (var i=0; i < len; i++) 
   {        
         if (inputs[i].getAttribute("type") == "text") 
         {    
                  var element = inputs[i];

                  element.onfocus = function() 
                  {    
                        var id = element.getAttribute("id");
                        alert(id);
                  }
          }
   }
}

function call(element)
{    
      element.value="";
}
</script>
</head>
<body>
<input type="text" name="myvar1" value="same content" id="noviceid" onfocus="call(this);">
<input type="text" name="myvar2" value="same content" id="noviceid" onfocus="call(this);">
</body>
</html>

请建议。我想同时调用onfocus。我是 JavaScript 新手。

4

1 回答 1

2

因此,一旦您的页面加载(使用适当的call onfocus处理程序),您运行window.onload的就会覆盖所有这些处理程序。我想这不是你打算做的。相反,如果可能,您可以使用 DOM2 事件:

element.addEventListener("focus", function(event) 
      {
            var id = event.target.getAttribute("id");
            alert(id);
      }, false);
于 2012-05-01T14:04:54.347 回答