本文使用图灵机器人API编写Html简单构建了一个网页,实现了聊天机器人。

原理:简单地向API地址发送请求,并获取回答信息,从而实现交互。

java网页机器人 机器人网页模板_.net

 页面使用Vue框架构建而成,注意其中的API key需要替换成自己的哦,在图灵机器人官网可以免费注册获得的!

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/axios@0.12.0/dist/axios.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/lodash@4.13.1/lodash.min.js"></script>
  </head>
  <body>
    <div id="app" class="flex">
    <br />
    <br />
    <h1 style="color: burlywood;">{{title}}</h1>
    <br />
    <br />
    <div id="app" class="box">
        <br />
        <br />
        <img :src="katouImage" style="width: 120px">
        <br />
        <br />
        <div class="answer">
            Katou:
            {{answer}}
        </div>
        <br />
        <br />
      <div>
         You:
        <input type="text" v-model="question"/>
      </div>
    </div>
    </div>
    <script type="text/javascript">
      var app = new Vue({
        el:"#app",
        data:{
          katouImage:"katou.jpg",
          question:'',
          answer:'你刚刚,说了什么?',
          title:"Virtual Friend Katou Megumi"
        },
        watch:{
          question(newv)
          {
            var func = _.debounce(this.getResult, 1000);  
            func();
          }
        },
        methods:{        
          getResult()
          {
            console.log("getresult");
            if(this.question.indexOf('?')== -1)
            {
              this.answer = "请以中文的 '?'结尾,yo!"
              return
            }
            axios.get('http://www.tuling123.com/openapi/api?key=这里输入自己的key哦&info=' + this.question)
                 .then(res=>{
                 console.log(res);
                 this.answer = res.data.text
               })
               .catch(function(err){
            }) 
          }
        }
      })
    </script>

<style>
    .flex {
      display: flex;
      flex-direction: column;
      align-items: center;
    }
    .box {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: space-evenly;
      width: 35rem;
      height: 22rem;
      background: #ffffff;
      border-radius: 14px;
      box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.5);
    }
    .answer{
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: space-evenly;
      width: 400px;
      height: 25px;
      background:lightskyblue;
      border-radius: 20px;
      box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.5);
    }
    </style>
  </body>
</html>