关联数组赋值js
<scripttype="text/javascript">functiona(){varstock={};varname=prompt("inputname"),sha...
<script type="text/javascript">
function a(){
var stock={};
var name=prompt("input name"),share=prompt("input share");
stock[name]=share;
for(stock[name] in stock){alert(stock[name]);}
for(var name in stock){
alert(name);
}
// 这种方式可以遍历关联数组中的各元素
for(var item in stock){
alert(stock[name]);
}
}
a();
</script>
输入name=微软,share=34,stock的name属性的值本来应该是share也就是34,为什么还是微软? 展开
function a(){
var stock={};
var name=prompt("input name"),share=prompt("input share");
stock[name]=share;
for(stock[name] in stock){alert(stock[name]);}
for(var name in stock){
alert(name);
}
// 这种方式可以遍历关联数组中的各元素
for(var item in stock){
alert(stock[name]);
}
}
a();
</script>
输入name=微软,share=34,stock的name属性的值本来应该是share也就是34,为什么还是微软? 展开
1个回答
展开全部
你的第一个例子并不是数组
而是创建了一个对象
循环输出的是这个对象的属性和值
第二个例子是数组
但是你把他当成一个对象来使用了
你的array2["A"]="a";
其实就是array2.A="a";
因为在数组的方括号里面只能填数字
所以你的赋值只是给你的array2添加了3个属性
分别是
array2.A="a"
array2.B="b"
array2.C="c"
而且你的循环都是用in来循环的
in的循环回输出这个对象的所有自定义属性
如果你用for(var i =0 ;i <array2.length;i++)的话
你什么都不会得到
而是创建了一个对象
循环输出的是这个对象的属性和值
第二个例子是数组
但是你把他当成一个对象来使用了
你的array2["A"]="a";
其实就是array2.A="a";
因为在数组的方括号里面只能填数字
所以你的赋值只是给你的array2添加了3个属性
分别是
array2.A="a"
array2.B="b"
array2.C="c"
而且你的循环都是用in来循环的
in的循环回输出这个对象的所有自定义属性
如果你用for(var i =0 ;i <array2.length;i++)的话
你什么都不会得到
追问
stock是作为一个关联数组的对象来操作的。而且没有第二个例子,就一个stock对象,有2个属性一个是name一个是shares。现在的问题是name值进去了,share虽然有值但是没传到stock对象里去
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询