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)
提前致谢!
答案 0 :(得分:1)
您的问题是您正在将函数checkCode
的结果设置为处理程序/属性而不是函数引用。你在调用它。
尝试:
b.onclick = checkCode;
或
b.on('click', checkCode);
您需要将函数的引用设置为处理程序。用()
设置它会调用函数然后在那里,因此你会看到行为。