微信小程式開發—專案實戰之聊天機器人

專案功能介紹

人工智慧虛擬機器器人“微軟小冰”大家玩過吧,很酷的一個應用。傳送文字、語音和圖片都能得到智慧的回覆。

那現在我們就用小程式做一個模擬的應用,智慧聊天機器人。傳送文字它可以回覆一段話,或一張圖片,是不是有點小酷!

下面是小程式開發的一個智慧聊天機器人的應用介面:

這裡寫圖片描述 這裡寫圖片描述

當然,這種智慧回覆的演算法和資料庫我們自己肯定是沒有的,所以我們藉助於圖靈機器人的開放API介面來完成我們的功能。

圖靈機器人介面:http://apistore.baidu.com/apiworks/servicedetail/736.html,在百度API store註冊獲取appkey就可以免費使用了。

智慧聊天機器人的開發步驟

1、整體框架

很簡單,兩個頁面。兩個tab,並修改window標題欄和tabBar的顏色等屬性就好。這個全部在app.json中完成。

2、image元件的使用

image元件介紹:https://mp.weixin.qq.com/debug/wxadoc/dev/component/image.html?t=20161122
image元件的使用與web開發的image標籤的用法類似。這裡主要關注image的mode屬性,它指定圖片的縮放以及裁剪模式,共提供了3種縮放、9種裁剪模式。

3、form表單的使用

表單,將元件內的使用者輸入的<switch/> <input/> <checkbox/> <slider/> <radio/> <picker/> 提交。

屬性名型別說明
report-submitBoolean是否返回formId用於傳送模板訊息
bindsubmitEventHandle攜帶form中的資料觸發submit事件,event.detail = {value : {‘name’: ‘value’} , formId: ”}
bindresetEventHandle表單重置時會觸發reset事件

當點選 表單中 formType 為 submit 的 <button/> 元件時,會將表單元件中的 value 值進行提交,需要在表單元件中加上 name 來作為 key

表單提交的要點:

  • 在form內的表單元件必須有name屬性。
  • 在form內的button的 formType 屬性為 submit 。
  • form的屬性bindsubmit即為資料提交事件繫結的響應函式。

4、wx.request介面的使用

wx.request發起的是 HTTPS 請求。一個微信小程式,同時只能有5個網路請求連線。
在開發除錯模式開發工具沒有做安全檢查,因此是可以請求http的

wx.request({
url: 'test.php', //僅為示例,並非真實的介面地址
data: {
x: '' ,
y: ''
},
header: {
'content-type': 'application/json'
},
method: 'GET',
success: function(res) {
console.log(res.data)
}
})

瞭解http的對這個介面引數應該不陌生,首先url為介面地址,data為請求的引數,header為請求的頭,header中不能設定header 中不能設定 Referer。method為請求的方法,包括:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT

5、scroll-view元件的使用

scroll-view為可滾動檢視容器。這個主要用於聊天介面在有新的訊息時需要自動滾動到最新聊天的位置。它的屬性還是比較多的,參看文件:https://mp.weixin.qq.com/debug/wxadoc/dev/component/scroll-view.html?t=20161122

屬性名型別預設值說明
scroll-xBooleanfalse
scroll-yBooleanfalse允許縱向滾動
upper-thresholdNumber50距頂部/左邊多遠時(單位px),觸發 scrolltoupper 事件
lower-thresholdNumber50距底部/右邊多遠時(單位px),觸發 scrolltolower 事件
scroll-topNumber設定豎向滾動條位置
scroll-leftNumber設定橫向滾動條位置
scroll-into-viewString值應為某子元素id,則滾動到該元素,元素頂部對齊滾動區域頂部
bindscrolltoupperEventHandle滾動到頂部/左邊,會觸發 scrolltoupper 事件
bindscrolltolowerEventHandle滾動到底部/右邊,會觸發 scrolltolower 事件
bindscrollEventHandle滾動時觸發,event.detail = {scrollLeft, scrollTop, scrollHeight, scrollWidth, deltaX, deltaY}

這裡我們主要用到scroll-y(允許縱向滾動)和scroll-top(設定豎向滾動條位置)屬性,以完成聊天內容的自動下翻。

6、兩個坑

a、更新資料同時更新scrollTop,無法達到效果
需要先更新資料,然後更新scrollTop

    要這樣寫才可以更新聊天頁面內容並將滾動條置於正確的位置
this.setData({content:newContent});
this.setData({scrollTop:newScrollTop});
而不能寫為下面這樣
this.setData({
content:newContent,
scrollTop:newScrollTop
});

b、textarea的value屬性繫結邏輯層的data資料段

在邏輯層呼叫setData({text:”“}),textarea中資料並不會被清空。這個問題還沒找出解決方案,等研究出方法再更新。

關於這個小程式的開發過程我錄製了視訊教程,教程是收費的,19元一杯咖啡的錢,掌握一門技術,有需要的可以購買。

智慧聊天機器人視訊教程地址:http://edu.csdn.net/course/detail/3370