微信小程序開發(fā)實(shí)現(xiàn)消息推送
微信小程序的消息推送簡(jiǎn)單的說就是發(fā)送一條微信通知給用戶,用戶點(diǎn)開消息可以查看消息內(nèi)容,可以鏈接進(jìn)入到小程序的指定頁面。
微信小程序消息推送需要用戶觸發(fā)動(dòng)作才能發(fā)送消息,比如用戶提交訂單、支付成功。一次只能發(fā)一條,當(dāng)然可以通過某種方法發(fā)送多條,小的就不在這里贅述了。下面就介紹一下如何推送消息。
一、準(zhǔn)備工作
首先,在微信公眾平臺(tái)開通消息推送功能,并添加消息模板。可以從模板庫選擇模板也可以創(chuàng)建一個(gè)模板,模板添加之后,模板ID我們接下來要用的。
發(fā)送模板消息需要用到accesstoken、formId和openID。accesstoken獲取及更新可以看我的上一篇文章;formID就是消息模板ID,openID我們最好在獲取用戶信息或用戶登錄時(shí)儲(chǔ)存到全局變量里。

二、獲取formID
在需要觸發(fā)消息推送的頁面添加提交表單的事件。目的是得到formID,formID是消息推送時(shí)必須的參數(shù)。
<form name='pushMsgFm' report-submit='true' bindsubmit='getFormID'> <button form-type="submit" class="zan-btn zan-btn--large zan-btn--danger payButton">立即支付</button> </form>
以上代碼中“getFormID”是提交表單時(shí)觸發(fā)的事件。
getFormID: function (e) {
this.setData({
formId: e.detail.formId }) }
以上方法是獲取formId。
三、配置消息模板參數(shù),并傳給后臺(tái)
var config = require('../config.js')
var app = getApp();
function pushMsg(formID, access_token){
var openId = app.globalData.userInfo.openId;
var messageDemo = {
touser: openId,//openId
template_id: 'PjtLeqq-UeF49r5jr88s27HBzBDobijr6QfiwJwIkPg',//模板消息id,
page: 'pages/index/index',//點(diǎn)擊詳情時(shí)跳轉(zhuǎn)的主頁
form_id: formID,//formID
data: {//下面的keyword*是設(shè)置的模板消息的關(guān)鍵詞變量
"keyword1": {
"value": "keyword1",
"color": "#4a4a4a"
},
"keyword2": {
"value": "keyword2",
"color": "#9b9b9b"
},
"keyword3": {
"value": "keyword3",
"color": "red"
}
},
color: 'red',//顏色
emphasis_keyword: 'keyword3.DATA'//需要著重顯示的關(guān)鍵詞
}
wx.request({
url: config.service.sendMsgUrl,
data: { value: messageDemo, access_token: access_token},
method: 'POST',
success: function (res) {
console.log("push msg");
console.log(res);
},
fail: function (err) {
console.log("push err")
console.log(err);
}
});
}
module.exports = { pushMsg: pushMsg }
四、推送消息
const request = require('../tools/ih_request');
var conf = require('../config.js')
module.exports = async (ctx, next) => {
var body = ctx.request.body.value
await request.postJson({
url: 'https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=' + ctx.request.body.access_token,
body: body,
success: function (res) {
ctx.body = {
result: res
}
console.log('res=',res);
},
error: function (err) {
ctx.body = {
result: err
}
console.log(err);
}
});}
ih_request.js
const request = require('request');
var ih_request = {};
module.exports = ih_request;
ih_request.postJson = async function (option) {
var res = await request({
url: option.url,
method: 'post',
headers: {
'content-type': 'application/json'
},
body: JSON.stringify(option.body),
}, function (err, res, body) {
res ? option.success(body) : option.error(res.msg);
console.log('MSGresult=', body);
});
}
為大家推薦現(xiàn)在關(guān)注度比較高的微信小程序教程一篇:《微信小程序開發(fā)教程》小編為大家精心整理的,希望喜歡。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
《javascript設(shè)計(jì)模式》學(xué)習(xí)筆記四:Javascript面向?qū)ο蟪绦蛟O(shè)計(jì)鏈?zhǔn)秸{(diào)用實(shí)例分析
這篇文章主要介紹了Javascript面向?qū)ο蟪绦蛟O(shè)計(jì)鏈?zhǔn)秸{(diào)用,結(jié)合實(shí)例形式分析了《javascript設(shè)計(jì)模式》中鏈?zhǔn)秸{(diào)用的原理與簡(jiǎn)單使用技巧,需要的朋友可以參考下2020-04-04
如何從JavaScript數(shù)組中刪除空對(duì)象
JS中數(shù)組是我們較為常用的一種數(shù)據(jù)結(jié)構(gòu),下面這篇文章主要給大家介紹了關(guān)于如何從JavaScript數(shù)組中刪除空對(duì)象的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
JS實(shí)現(xiàn)將鏈接生成二維碼并轉(zhuǎn)為圖片的方法
這篇文章主要介紹了JS實(shí)現(xiàn)將鏈接生成二維碼并轉(zhuǎn)為圖片的方法,涉及qrcodejs插件及js圖片生成相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
JavaScript隨機(jī)數(shù)的組合問題案例分析
這篇文章主要介紹了JavaScript隨機(jī)數(shù)的組合問題,結(jié)合具體案例形式分析了JavaScript隨機(jī)數(shù)的組合問題相關(guān)算法原理、實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下2020-05-05
輸入自動(dòng)提示搜索提示功能的javascript:sugggestion.js
該js文件中的代碼實(shí)現(xiàn)了[輸入自動(dòng)搜索提示]功能,如百度、google搜索框中輸入一些字符會(huì)以下拉列表形式給出一些提示,提高了用戶體驗(yàn)2013-09-09

