天天看點

圖靈聊天機器人小程式

項目描述:

  • 根據圖靈API向聊天機器人發送聊天資訊,并渲染傳回的資料。
  • 具有清空聊天記錄的按鈕。
  • 本來是想上線體驗版,但體驗版就是發送不了資訊,真機調試都好好的,
  • 圖靈的聊天API免費接口一台終端一天大概隻有十幾次的請求…

來個圖

圖靈聊天機器人小程式

用到的元件和API:

  • API主要用到是用于發送post請求的wx.request(),點選事件的綁定和送出事件的綁定。
  • 元件主要用的是可滾動視圖元件和用于循環生成對話的block元件。

生成對話的方式:

  • 首先擷取到submit事件的事件對象,然後通過e.detail.value.say擷取到你輸入的資訊,(say屬性需要在input框的name屬性定義);
  • 然後以{key: ‘你注冊的圖靈API得到的key’, info: 你輸入的資訊}的方式向http://www.tuling123.com/openapi/api發送POST請求,然後将拿到的資料和你輸入的資料作為一個對象利用setData利用push方法添加到對話數組裡,然後小程式會根據新資料重新渲染頁面。

wxml部分

<view class="title">{{title}}</view>
<!-- 對話部分 -->
<view class="que" >
  <scroll-view class="con" scroll-y>
    <block wx:for="{{says}}" wx:for-item="item" wx:key="index">
      <!-- 我說的話以及我的圖檔 -->
      <view class="iSay">
        <view class="right-img">
          <image src="{{headRight}}"></image>
        </view>
        <view class="right-text">
          <view>{{item.iSay}}</view>
        </view>
      </view>


      <!-- 機器人說的話以及機器人的圖檔 -->
      <view class="robotSay">
        <view class="left-img">
          <image src="{{headLeft}}"></image>
        </view>
        <view class="left-text">
          <view>{{item.rSay}}</view>
        </view>
      </view>
    </block>
  </scroll-view>

</view>

<!-- 按鈕部分 -->
<view class="bottom">
  <view class="send">
    <form bindsubmit="converSation">
      <input type="text" placeholder="說點什麼吧~" name="say" value="{{tempISay}}"></input>
      <button class="btn-d" bindtap="deleteChat">清空</button>
      <button class="submit" id="btn" form-type="submit">發送</button>
    </form>
  </view>
</view>
           

wxss部分

/* 标題部分 */
.title {
  position: fixed;
  height: 6vh;
  width: 100%;
  top: 0px;
  line-height: 80rpx;
  text-align: center;
  font-size: 40rpx;
  font-weight: bold;
  background-color: #fff;
  color: black;
  box-shadow: 16rpx -4rpx 30rpx rgb(209, 204, 204);
}

/* 對話框部分 */
.que {
  width: 98%;
  margin-top: 7vh;
  height: 83vh;
  margin-left: 1%;
  box-sizing: border-box;
  overflow: hidden;
}

.con {
  width: 95%;
  height: 100%;
  margin-left: 20rpx;
}

.iSay {
  width: 70%;
  margin-left: 30%;
  margin-top: 60rpx;
}

.iSay .right-img {
  position: relative;
  height: 60rpx;
  width: 60rpx;
  left: 88%;
  margin-top: 5rpx;
}

.iSay .right-text {
  width: 80%;
  margin-top: -65rpx;
}

.iSay .right-text view {
  padding: 10rpx 30rpx;
  text-overflow: ellipsis;
  word-wrap: break-word;
  border-radius: 30rpx;
  background-color: #eee;
  color: green;
  font-size: 25rpx;
}

.robotSay {
  width: 70%;
  margin-top: 30rpx;
}

.robotSay .left-img {
  width: 75rpx;
  height: 80rpx;
}

.robotSay .left-text {
  width: 80%;
  margin-left: 20%;
  margin-top: -60rpx;
}

.robotSay .left-text view {
  padding: 10rpx 30rpx;
  text-overflow: ellipsis;
  word-wrap: break-word;
  border-radius: 30rpx;
  background-color: #eee;
  color: green;
  font-size: 25rpx;
}

/* 按鈕部分 */
.bottom {
  position: fixed;
  width: 100%;
  height: 10vh;
  bottom: 0rpx;
  background-color: gray;
}

.send {
  position: fixed;
  width: 100%;
  bottom: 20rpx;
  height: 66rpx;
}

input {
  width: 55%;
  height: 66rpx;
  padding-left: 40rpx;
  box-sizing: border-box;
  border-radius: 30rpx;
  border: 1rpx solid black;
  background-color: #fff;
}

.send button {
  float: right;
  width: 20%;
  height: 66rpx;
  bottom: 66rpx;
  margin-right: 10rpx;
  border-radius: 30rpx;
  line-height: 66rpx;
  color: #fff;

}

.send button.submit {
  background-color: rgb(62, 214, 143);
}

.send button.btn-d {
  background-color: black;
}

.robotSay .left-img image,
.iSay .right-img image {
  height: 100%;
  width: 100%;
  border-radius: 50%;
}
           

js部分

Page({

  /**
   * 頁面的初始資料
   */
  data: {
    title: 'Chat Robot',
    headLeft: '',
    headRight: '',
    says: [
      {
        rSay: '你好,來和我聊聊天吧~~~',
        iSay: '你好',
      },
    ],
    tempISay: '',
  },
  /**
    * 生命周期函數--監聽頁面加載
    */
  onLoad: function () {
    let That = this;
    //擷取使用者的目前設定。傳回值中隻會出現小程式已經向使用者請求過的權限。
    wx.getSetting({
      //傳回成功時
      success: function (res) {
        //授權使用者資訊
        if (res.authSetting['scope.userInfo']) {
          wx.getUserInfo({
            success: function (res) {
              That.setData({
                headRight: res.userInfo.avatarUrl,
              })
            }
          });
        }
      }
    })
  },


  // 綁定input框的送出事件
  converSation(e) {
    let That = this;
    let says = this.data.says;
    let key = '9bfb8444a1324d82bfc15ba46e6ca3c2';
    let newSays = {};
    newSays.iSay = e.detail.value.say;

    // 發送請求
    newSays.iSay && wx.request({
      url: 'http://www.tuling123.com/openapi/api',
      data: {
        key: key,
        info: newSays.iSay
      },
      header: {
        'content-type': 'application/json'
      },
      success(res) {
        newSays.rSay = res.data.text;
        says.push(newSays);


        // tempISay用于做中間變量,資料送出後将輸入框裡的内容清空
        That.setData({
          says: says,
          tempISay: '',
        })
      },
    })
  },


  // 清空對話内容
  deleteChat() {
    this.setData({
      says: [],
    })
  }
})
           

繼續閱讀