最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Getting getElementById is Undefined - Stack Overflow

programmeradmin2浏览0评论

Here's my code:

<html>
<header>
<title>Checkup Date</title>
<script type="text/javascript">
function datechange() {
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject

("Microsoft.XMLHTTP");

  }

var tr = getElementsById(nameUpdate)
var tds = tr.getElementsByTagName('td');
var user = "";
var date = "";
for(var i = 0, len = tds.length; i < len; ++i) {
    user = tds[0];
    date = tds[3];
}


var url = "changedate.psp"
var params = "user=" + user + "&date=" + date;

xmlhttp.open("GET", url + "?" + params, true);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML;

}

</script>
</header>

<body>

<%
Python that doesn't matter
%>

<%= More Python %>

</body>
</html>

My outputted HTML:

<tr id="TL-D03">
<td>nobody</td>
<td>TL-D03</td>
<td>2010-01-01</td>
<td>
<input type="checkbox" onclick="var nameUpdate = 'TL-D03'; datechange();">

What am I doing wrong here? It says getElementById is undefined.

Here's my code:

<html>
<header>
<title>Checkup Date</title>
<script type="text/javascript">
function datechange() {
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject

("Microsoft.XMLHTTP");

  }

var tr = getElementsById(nameUpdate)
var tds = tr.getElementsByTagName('td');
var user = "";
var date = "";
for(var i = 0, len = tds.length; i < len; ++i) {
    user = tds[0];
    date = tds[3];
}


var url = "changedate.psp"
var params = "user=" + user + "&date=" + date;

xmlhttp.open("GET", url + "?" + params, true);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML;

}

</script>
</header>

<body>

<%
Python that doesn't matter
%>

<%= More Python %>

</body>
</html>

My outputted HTML:

<tr id="TL-D03">
<td>nobody</td>
<td>TL-D03</td>
<td>2010-01-01</td>
<td>
<input type="checkbox" onclick="var nameUpdate = 'TL-D03'; datechange();">

What am I doing wrong here? It says getElementById is undefined.

Share Improve this question asked Nov 10, 2011 at 18:44 Steven MatthewsSteven Matthews 11.4k50 gold badges137 silver badges253 bronze badges 1
  • why would you do var nameUpdate = 'TL-D03'; datechange();? Pass it as a argument to the function! – epascarello Commented Nov 10, 2011 at 18:52
Add a ment  | 

6 Answers 6

Reset to default 3

getElementById is a function of document:

var tr = document.getElementById("nameUpdate")

MDN: https://developer.mozilla/en/DOM/document.getElementById

Problem 1: you're calling getElementsById. IDs are unique: the function is getElementById. No s.

Problem 2: getElementById is not a global function. You need to call it on the document object:

var tr = document.getElementById(nameUpdate)

After all, your script could reference more than one document (for example, with an iframe), so you need to be explicit about where you expect the element to be.

Also try changing:

<input type="checkbox" onclick="var nameUpdate = 'TL-D03'; datechange();">

to this:

<input type="checkbox" onclick="datechange('TL-D03')">

and

function datechange() {

to this

function datechange(nameUpdate) {

makes more sence

It's document.getElementById(), not getElementsById(), as it only returns one element.

The latter would not be very useful, since id attributes must be unique within an HTML document.

you need to use document.getElementById("yourelementid")

The reason it doesn't work is that var scopes a variable to the function it is defined in, so it isn't readable outside the anonymous function assigned to the onclick handler.

In more general "wrongness" terms, passing data about using globals is generally a bad idea.

Pass it as an argument instead.

function datechange(nameUpdate) {

and

datechange('TL-D03');
发布评论

评论列表(0)

  1. 暂无评论