91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序開發遇到的問題怎么解決

發布時間:2022-04-20 14:15:44 來源:億速云 閱讀:147 作者:iii 欄目:大數據

這篇文章主要介紹“微信小程序開發遇到的問題怎么解決”,在日常操作中,相信很多人在微信小程序開發遇到的問題怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”微信小程序開發遇到的問題怎么解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

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更新后會解決這個問題.

到此,關于“微信小程序開發遇到的問題怎么解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

佛坪县| 自治县| 龙游县| 江门市| 漠河县| 吉首市| 新乡县| 丰城市| 吉林市| 长宁区| 城步| 成武县| 大宁县| 岚皋县| 长兴县| 通海县| 宁安市| 孝感市| 刚察县| 苏尼特右旗| 田东县| 志丹县| 西丰县| 应城市| 河南省| 确山县| 襄城县| 巴东县| 余姚市| 沁源县| 鄯善县| 小金县| 贞丰县| 获嘉县| 泰兴市| 鄂伦春自治旗| 山东省| 金门县| 荃湾区| 册亨县| 苏尼特左旗|