0

浏览器聊天的以下代码作为一个整体工作,但它并不整洁。

<p>chat in silence:</p>
<input id="yousay" name="input" size="52" onkeydown="if (event.keyCode == 13) { doTalk(); }"/>

<p>chat in with music:</p>
 <textarea onfocus="clearContents(this);" id="chat" cols="50" rows="2" ></textarea>

 <button type="button" onclick="triggerAll();">answer</button>

这些是脚本:

<script src="scripts/soundEngine.js"></script>
<script src="scripts/animationEngine.js"></script> 
<script src="scripts/talk.js"></script>

这调用了机器人 API

<script>
  var pb = new Pandorabot("aiaas.pandorabots.com", 'validid', 'validname', 'validid'); 
  function doTalk() {
    var input = document.getElementById("yousay").value;
    document.getElementById("yousay").value = "";
    pb.talk(input, function(data) {
      var response = data["responses"];
      document.getElementById("response").innerHTML = response;
      console.log(response);
    });
  }
</script>

这是一个一次调用它们的函数:

<script>
      function triggerAll(){
        doTalk();
        play_song();
        animate_song();
      }
</script>

显然,<textarea>调用play_song()and animate_song(),但不调用doTalk()

有没有一种方法可以将所有函数调用放在一个中tag 并减少代码?

4

2 回答 2

2

在 html 中,您可以调用调用所有这些函数的函数。就像你有脚本一,二,三,你这样做

<randomtag onclick="call_all()"></randomtag>

<script type="text/javascript">
  function call_all(){
    one();
    two();
    three();
  }
</script>
于 2016-07-05T17:22:10.273 回答
0
var pb = new Pandorabot("aiaas.pandorabots.com", 'validid', 'validname', 'validid');

这里的论点有效吗?如果此参数无效,则函数doTalk()不存在并且您不能调用它们

于 2016-07-05T17:27:49.427 回答