追加按钮不起作用

时间:2013-09-20 05:47:04

标签: javascript button append

function story1(){
var t=document.createElement('p');
t.innerHTML = "You wake up from your sleep in a half daze to hear noises of screams outside your bedroom window. You stumble over there to see what is the matter. You decide it's a good idea to grab your"+' <i onclick=addSword()> '+" sword "+' </i> '+"as you take the "+' <i onclick=story2()> '+" stairs. "+'</i>';
document.getElementById("story").appendChild(t);
}

function story2(){
var t = document.createElement('p');
t.innerHTML = "You realize that the door is locked and need to break the code in order to go outside." +' <i id="one" onclick=addOne()> '+ num1 +'</i>'+' <i id="two" onclick=addTwo()> '+ num2+'</i>'+' <i id="three" onclick=addThree()> '+ num3 +'</i>';
document.getElementById("story").appendChild(t);
var b = document.createElement('input');
b.type = 'button';
b.value = 'Check Code';
b.onclick = checkCode();
document.getElementById("story").appendChild(b);
}

简而言之,这两个功能是我的问题所在。我试图在div中添加一个按钮来检查代码是否坏了。 checkCode的编码按原样运行。

问题是,当点击楼梯而不是按钮时,checkCode()实际上正在工作。我已尝试b.on('click', checkCode())b.setAttribute('onclick', checkCode())

也许我没有正确编码按钮,但教程和阅读类似问题的答案只能让我到目前为止! (LOL)

提前致谢!

1 个答案:

答案 0 :(得分:1)

您的问题是您正在将函数checkCode的结果设置为处理程序/属性而不是函数引用。你在调用它。

尝试:

b.onclick = checkCode;

b.on('click', checkCode);

您需要将函数的引用设置为处理程序。用()设置它会调用函数然后在那里,因此你会看到行为。