我有一系列按钮,上面有一些名字;单击按钮时,按钮上的名称将添加到列表中.最后一个操作由一个函数完成,该函数将按钮的id作为输入.当我明确地写下所有这些东西时,一切都很好:

<!DOCTYPE html>
<html>
<head>
    <script>
        inventory=[]

        function addinv(variable) {
            item=document.getElementById(variable).innerHTML
            if (item!='Ok') {
                if (inventory.length<2){
                    inventory.push(item)
                    document.getElementById(variable).innerHTML='Ok'
                }
            }

        }

        function location0() {
            document.getElementById("1").innerHTML="Spada"
            document.getElementById("1").setAttribute('onclick','addinv(1)')
            document.getElementById("2").innerHTML="Corda"
            document.getElementById("2").setAttribute('onclick','addinv(2)')
            document.getElementById("3").innerHTML="Acciarino"
            document.getElementById("3").setAttribute('onclick','addinv(3)')
        }

    </script>
</head>
<body>
    <button type="button" id="1" onclick=""></button>
    <button type="button" id="2" onclick=""></button>
    <button type="button" id="3" onclick=""></button>
    <script>location0()</script>


</body>
</html>

我想使用for循环来设置按钮上的名称并调用addinv函数.为此,我将函数location0更改如下:

function location0() {
    equip=["Spada", "Corda", "Acciarino"]
        for (i=1; i<4; i++) {
            document.getElementById(i).innerHTML=equip[i-1]
            document.getElementById(i).setAttribute('onclick','addinv(i)')
        }
    }

现在按钮上仍然有正确的名称,但addinv函数不能正常工作:在我看来,所有按钮都调用addinv(4)

推荐答案

try 按以下方式更换for循环:

for (let i=1; i<4; i++) {
   document.getElementById(i).innerHTML=equip[i-1]
   document.getElementById(i).addEventListener("click",()=>{addinv(i)});
}

我附上了一张sample code英镑供你参考.

Javascript相关问答推荐

Chart.js V4切换图表中的每个条,同时每个条下有不同的标签.怎么做?

使用下表中所示的值初始化一个二维数组

在带有背景图像和圆形的div中添加长方体阴影时的重影线

如何控制Reaction路由加载器中的错误状态?

在执行异步导入之前判断模块是否已导入()

rxjs插入延迟数据

使用js构造一个html<;ath&>元素并不能使其正确呈现

Webpack在导入前混淆文件名

如何在一个对象Java脚本中获取不同键的重复值?

如何更改Html元素S的 colored颜色 ,然后将其褪色为原始 colored颜色

JavaScript -复制到剪贴板在Windows计算机上无效

如何使用puppeteer操作所有选项

如何使用Reaction路由导航测试挂钩?

有没有办法在R中创建一张具有多个色标的热图?

如何在Reaction中设置缺省值, Select 下拉列表,动态追加剩余值?

Reaction-在同一页内滚动导航(下拉菜单)

如何在不将整个文件加载到内存的情况下,在Node.js中实现Unix粘贴命令?

我如何让我的弹力球在JavaScript和HTML画布中相互碰撞后改变 colored颜色 ?

动画可以在Chrome上运行,但不能在Safari上运行

.Remove()函数不适用于MongoDB