javascript数组在文本区域中显示未定义

时间:2013-12-13 06:14:14

标签: javascript arrays undefined

所以我现在正在做一些家庭工作,我很难理解为什么我的数组显示为未定义。对不起,如果这很简单,但我对此很新。我会尝试解释我在这里做的事情。

我有三个输入字段,我收集学生的姓氏,名字和成绩。我通过他们的id得到所有这些元素,并将所有这些输入放入一个名为studentGrade的数组中。然后我将该数组的内容推送到另一个名为grade的数组中,然后将其作为参数传递给名为get_item_list的函数。从那里我尝试循环遍历该参数的内容,以便我可以将其显示到id为“scores”的文本字段。

我非常感谢所有的投入,并希望我能够了解我做错了什么。

var grades = [];

var $ = function (id) { return document.getElementById(id); }

var update_display = function () {
    $("scores").value = get_item_list(grades);

    $("last_name").value = "";
    $("first_name").value = "";
    $("score").value = "";

$("last_name").focus();
}    

var student_grade_add_click = function() {
    var studentGrade = [];
    studentGrade["last_name"] = $("last_name").value;
    studentGrade["first_name"] = $("first_name").value;
    studentGrade["score"] = parseFloat($("score").value);

    if ( studentGrade["last_name"] == "" ) return;
    if ( studentGrade["last_name"] == "" ) return;
    if ( isNaN(studentGrade["score"]) ) return;

    grades.push(studentGrade);
    update_display();
}

var get_item_list = function(item_list) {
    if ( item_list.length == 0 ) {
       return "";
    }
    var list;
    for ( var i in item_list ) {
        list += item_list[i] + "\n";
    }
    return list;
}

window.onload = function () {
    $("add_button").onclick = student_grade_add_click;
    $("last_name").focus();
}

这是我正在使用的javascript

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Student Scores</title>
<link rel="stylesheet" type="text/css" href="default.css" />
<script type="text/javascript" src="student_scores.js"></script>
</head>

<body>
<div id="content">
    <h1>Student Scores</h1>
    <div class="formLayout">
        <label>Last Name:</label>
        <input type="text" id="last_name" /><br />

        <label>First Name:</label>
        <input type="text" id="first_name" /><br />

        <label>Score:</label>
        <input type="text" id="score" /><br />

        <label>&nbsp;</label>
        <input type="button" id="add_button" value="Add Student Score" /><br />
     </div>
    <h2>Student Scores</h2>
    <p><textarea id="scores" rows="5" cols="60"></textarea></p>
     <div class="formLayout">
        <label>Average score:</label>
        <input type="text" id="average_score"/><br />

        <label>&nbsp;</label>
        <input type="button" id="clear_button" value="Clear Student Scores" /><br />

        <label>&nbsp;</label>
        <input type="button" id="sort_button" value="Sort By Last Name" /><br />
    </div>
</body>
</html>

并且有我制作的HTML,再次感谢。

1 个答案:

答案 0 :(得分:1)

我认为在将值连接到它之前需要将list初始化为字符串:

var get_item_list = function(item_list) {
    if ( item_list.length == 0 ) {
       return "";
    }
    var list = "";
    for ( var i = 0; i < item_list.length; i++) {
       var current = item_list[i];
       for ( var attr in current ) {
           list += current[attr] + "\n";
       }
    }
    return list;
}

另外,studentGrade不是数组,它是一个对象(即使你像设置数组一样设置键):

var studentGrade = {};

我的更改有效,这是您更新的小提琴:http://jsfiddle.net/LFhNQ/1/