我想创建一个更改数组中元素值的按钮。我试图通过以下代码来做,但元素不会改变。作为一个自学初学者,我可能会遗漏一些非常明显的东西,如果有人能指出这一点我会很感激。
感谢您的回答!
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>Change Array Value</title>
</head>
<body>
<textarea id="log2"></textarea>
<input type="button" onClick="uClicked();" value="Click!">
<script>
var fer=[];
for (i=0; i< 15; i++){
fer[i]=i+1;
}
function uClicked(fer){
fer[12] = 10;
return fer[12];
}
log2.value = "fer[12]= " + fer[12];
</script>
</body>
</html>
答案 0 :(得分:6)
function uClicked(){ // remove the parameter.
不需要参数,隐藏真实的fer
变量。
由于fer
在外部范围内声明,uClicked
函数可以访问它。
固定代码:
var fer=[];
for (i=0; i< 15; i++){
fer[i]=i+1;
}
function uClicked(){
fer[12] = 10;
alert(fer[12]);
}
答案 1 :(得分:3)
您的评论代码
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>Change Array Value</title>
</head>
<body>
<textarea id="log2"></textarea>
<input type="button" onClick="uClicked();" value="Click!">
<script>
var fer=[];
for (i=0; i< 15; i++){ //use var i, otherwise you are putting i in the global scope
fer[i]=i+1;
}
function uClicked(fer){ // fer is undefined because you are not passing argument when you call the function
fer[12] = 10;
return fer[12];
}
log2.value = "fer[12]= " + fer[12]; //log2 is not defined.
</script>
</body>
</html>
工作代码:
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>Change Array Value</title>
</head>
<body>
<textarea id="log2"></textarea>
<input type="button" onclick="uClicked();" value="Click!" />
<script type="text/javascript">
var fer = [];
for(var i; i < 15; i++){
fer[i]=i+1;
}
var log2 = document.getElementById("log2");
function uClicked(){
fer[12] = 10;
log2.value = "fer[12]= " + fer[12];
return fer[12];
}
</script>
</body>
</html>