前言
- 經過將近一個多月的開發,我們團隊開發的微信小程式 “出發吧一起” 終於開發完成,現在的線上版本為 2.2.4-beta 版本文章主要介紹該小程式在開發中所用到的技術,已經在開發中遇到問題的採取的解決方法
- 開源地址
開發中技術問題彙總
1.使用e.target.dataset的出現問題
在小程式開發過程中,我們經常會用到標籤中屬性的屬性值,我們通常會在 <view>
中 設定 data-*="{{XXX}}"
然後在 JS
裡通過 e.target.dateset.*
來獲取XXX
值,但是我經常遇到獲取的是undefined
,使用 console.log(e)
檢視輸出資訊會發現,在 e
物件中包含兩個物件分別是currentTarget
和target
,而往往有些時候資料在currentTarget
中,
此時可以將程式碼替換成這樣來獲取值
- WXML
<view bindtap="bintap" data-id="1"></view>
- JS
bintap:function(e){
var id = e.currentTarget.dataset.id;
}
網上還有一直說法是 data-*
裡 *
命名的問題,去掉駝峰式命名,純小寫也能解決
2.小程式 textarea 文字框如何顯示實時字數
- WXML
<view>
<view>
<textarea name="content" bindinput="bindTextAreaChange" maxlength="{{noteMaxLen}}" />
<view class="chnumber">{{noteNowLen}}/{{noteMaxLen}}</view>
</view>
</view>
- JS
data:{
noteMaxLen: 200,//備註最多字數
noteNowLen: 0,//備註當前字數
}
//字數改變觸發事件
bindTextAreaChange: function (e) {
var that = this
var value = e.detail.value,
len = parseInt(value.length);
if (len > that.data.noteMaxLen)
return;
that.setData({
content: value, noteNowLen: len
})
},
3.利用 JS 實現模糊查詢
由於我們使用的是 Bmob 後端雲提供的資料處理與儲存支援,根據 Bmob 提供的開發文件,免費版的應用無法進行模糊查詢,看到這裡,再看看已經快完工的活動檢索介面,感受無法言說。正當準備放棄的時候,突然想到一個方法,那就是先把所有的後臺所有資料都存到集合裡,然後根據輸入的檢索值一個個匹配,想到之後馬上就開始著手幹了,先查了一下javaScript
文件,String
物件有一個方法是 indexOf()
,可返回某個指定的字串值在字串中首次出現的位置,這樣就成了,遍歷 所以資料,檢索每一條資料的每個字元,如果出現了則將它加入到檢索結果的集合中.
- JS
//js 實現模糊匹配查詢
findEach: function (e) {
var that = this
var strFind = that.data.wxSearchData.value; //這裡使用的 wxSearch 搜尋UI外掛,
if (strFind == null || strFind == "") {
wx.showToast({
title: `輸入為空`,
icon: `loading`,
})
}
if (strFind != "") {
var nPos;
var resultPost = [];
for (var i in smoodList) {
var sTxt = smoodList[i].title || ``; //活動的標題
nPos = sTxt.indexOf(strFind);
if (nPos >= 0) {//如果輸入的關鍵字在該活動標題中出現過,則匹配該活動
resultPost.push(smoodList[i]); //將該活動加入到搜尋到的活動列表中
}
}
that.setData({
moodList: resultPost
})
}
},
更加詳細的程式碼請前往Github檢視
4.使用 JS 將字串格式的時間轉換成幾秒前,幾分鐘前…
由於小程式中涉及評論,加入活動,收藏等一系列包括事件時間的功能,而資料庫中存的時間格式為 2017-11-30 23:36:10
現在想要在介面上不顯示具體時間,而是顯示與當前時間的差,即幾秒前,幾分鐘前等等
實現起來並不複雜,主要思路是先把字串的時間轉換成時間戳,然後與當前的時間戳進行比較,這樣就能轉換成幾秒前、幾分鐘前、幾小時前、幾天前等形式了
- JS
//字串轉換為時間戳
function getDateTimeStamp(dateStr) {
return Date.parse(dateStr.replace(/-/gi, "/"));
}
//格式化時間
function getDateDiff(dateStr) {
var publishTime = getDateTimeStamp(dateStr) / 1000,
d_seconds,
d_minutes,
d_hours,
d_days,
timeNow = parseInt(new Date().getTime() / 1000),
d,
date = new Date(publishTime * 1000),
Y = date.getFullYear(),
M = date.getMonth() + 1,
D = date.getDate(),
H = date.getHours(),
m = date.getMinutes(),
s = date.getSeconds();
//小於10的在前面補0
if (M < 10) {
M = `0` + M;
}
if (D < 10) {
D = `0` + D;
}
if (H < 10) {
H = `0` + H;
}
if (m < 10) {
m = `0` + m;
}
if (s < 10) {
s = `0` + s;
}
d = timeNow - publishTime;
d_days = parseInt(d / 86400);
d_hours = parseInt(d / 3600);
d_minutes = parseInt(d / 60);
d_seconds = parseInt(d);
if (d_days > 0 && d_days < 3) {
return d_days + `天前`;
} else if (d_days <= 0 && d_hours > 0) {
return d_hours + `小時前`;
} else if (d_hours <= 0 && d_minutes > 0) {
return d_minutes + `分鐘前`;
} else if (d_seconds < 60) {
if (d_seconds <= 0) {
return `剛剛`;
} else {
return d_seconds + `秒前`;
}
} else if (d_days >= 3 && d_days < 30) {
return M + `-` + D + ` ` + H + `:` + m;
} else if (d_days >= 30) {
return Y + `-` + M + `-` + D + ` ` + H + `:` + m;
}
}
5.微信小程式提交表單清空表單資料
在釋出活動之後,由於表單中的資料沒有清空,給使用者的體驗必定不好,然而小程式的資料互動並不像html + jS
那樣,使用 dataSet({})
來給賦值,檢視層就能通過非同步的方式活動到值,於是想到,在提交表單後,給這些input
都賦值為空,那樣就實現了清空表單的效果,當然,表單中並不只包含input
,但是都可以通過這種方式實現清空效果
- WXML
<form bindsubmit="submitForm">
<text class="key">活動名稱</text>
<input name="title" maxlength="100" value="{{title}}" />
<button formType="submit">確定</button>
</form>
- JS
submitForm:function(e){
var title = e.detail.value.title;
......
success: function (res) {
//將title值設定空
that.setData({
title: ``
}
}
}
6.微訊號,QQ號,手機號 正則校驗
由於申請加入活動需要填寫真實姓名,聯絡方式等資訊,為了防止使用者隨意填寫資訊,必須要對這些資訊進行校驗
- JS
var wxReg = new RegExp("^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$"); //微訊號正則校驗
var qqReg = new RegExp("[1-9][0-9]{4,}"); //QQ號正則校驗
var phReg = /^1[34578]d{9}$/; //手機號正則校驗
var nameReg = new RegExp("^[u4e00-u9fa5]{2,4}$"); //2-4位中文姓名正則校驗
7.使用 Bmob SDK 實現報名成功傳送模板訊息,生成小程式二維碼等
在開發過程中,由於想要實現,當使用者報名成功後如何通知使用者,查閱了小程式的開發文件發現有一個傳送模板訊息的API,再查詢 Bmob 的開發文件,發現實現了這個功能,這個真的太有用了.模板訊息只能再真機上才能傳送成功,經過配置,重要成功,但是有在使用中出現一個問題
,就是在小程式釋出後 模板訊息中如果帶有 page
引數將不會傳送,但是在開發版中能傳送成功, 這個問題已經反饋了,估計等Bmob小程式SDK
更新後會解決這個問題.
具體程式碼我就不寫了,bmob開發文件直達