真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

詳解小程序input框失焦事件在提交事件前的處理

無(wú)論是小程序還是平常的Html頁(yè)面,input文本框我們用到的次數(shù)都很多,這一篇文章主要是講關(guān)于小程序中文本框聚焦自動(dòng)拉起輸入鍵盤的一些使用心得。

愛輝ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來(lái)市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

為什么我需要聚焦拉起鍵盤呢?為什么我棄用失焦事件呢?

因?yàn)樵谖业男〕绦蛭恼轮刑峁┝嗽u(píng)論文章的功能,昨天空閑下來(lái)我想將回復(fù)評(píng)論的功能也做一下,我想讓回復(fù)和評(píng)論同時(shí)共用一個(gè)文本框如下圖一,我來(lái)說(shuō)明一下的操作:當(dāng)我們進(jìn)入文章界面的時(shí)候,輸入框模式默認(rèn)是評(píng)論文章的,但是如果我們點(diǎn)擊回復(fù)就會(huì)出現(xiàn)圖二的情況,在文本框出現(xiàn)回復(fù)XXX的評(píng)論,這里有個(gè)過(guò)程:當(dāng)我們點(diǎn)擊回復(fù)的時(shí)候首先讓該文本框聚焦(focus="{{focus}}為true的時(shí)候就會(huì)聚焦),手機(jī)上會(huì)自動(dòng)拉起輸入框,然后在該文本框上賦值"回復(fù)XXX的評(píng)論"。為什么要文本框賦值呢?因?yàn)槲矣?文本內(nèi)容.indexOf("[回復(fù)XXX的評(píng)論:]")==0"來(lái)區(qū)分是回復(fù)文章還是回復(fù)評(píng)論。

在一開始的時(shí)候我并非這樣設(shè)計(jì)的,我當(dāng)時(shí)想的是:既然點(diǎn)擊回復(fù)會(huì)聚焦拉起文本框,那么失焦的時(shí)候我在把文本框改為評(píng)論文章吧,但是測(cè)試的時(shí)候就出現(xiàn)了一個(gè)問(wèn)題:我點(diǎn)擊回復(fù)的時(shí)候文本框失焦觸發(fā)的方法在回復(fù)按鈕觸發(fā)之前,也就說(shuō)回復(fù)評(píng)論變成了評(píng)論文章,當(dāng)時(shí)想到的一個(gè)解決辦法是定時(shí)器,讓失焦事件方法體延遲執(zhí)行,雖然達(dá)到了效果,但是也有問(wèn)題:用戶回復(fù)評(píng)論的時(shí)候,突然不想評(píng)論了,點(diǎn)擊屏幕的其他地方,此時(shí)應(yīng)該立刻按鈕變成發(fā)表,文本框的placeholder變成評(píng)論文章,但是由于延遲所以會(huì)過(guò)一會(huì)才變回去,不太友好。那么怎么辦呢?我就想起了CSDN回復(fù)評(píng)論的功能,我們回復(fù)評(píng)論的時(shí)候會(huì)帶上replyXXX的效果,我就想這個(gè)是不是判斷回復(fù)文章還是回復(fù)評(píng)論的區(qū)別,然后我就這樣做了。我們往下看具體的實(shí)現(xiàn)

詳解小程序input框失焦事件在提交事件前的處理      

詳解小程序input框失焦事件在提交事件前的處理

那我們來(lái)具體的看代碼:


 

上面就是文本框和按鈕以及綁定的事件,我們主要來(lái)看JS:

首先我們要看一下點(diǎn)擊回復(fù)拉起鍵盤的事件:代碼里面id為文章評(píng)論的id,name為評(píng)論人的姓名,focus就是聚焦設(shè)為true,insertorfeed是按鈕顯示的值,一開始為評(píng)論,點(diǎn)擊回復(fù)之后按鈕變成回復(fù),placeholder變成回復(fù)評(píng)論,content自動(dòng)加上"[回復(fù)XX的評(píng)論]".

 feedbackCom: function(e) {
  var id = e.currentTarget.dataset.id
  var name = e.currentTarget.dataset.name
  var index = e.currentTarget.dataset.index
  console.log(id + name + index)
  this.setData({
   id: id,
   index: index,
   focus: true,
   insertorfeed: "回復(fù)",
   comorfeed: "回復(fù)評(píng)論",
   content: "[回復(fù)" + name + "評(píng)論]:"
  })
 },

分析完點(diǎn)擊回復(fù)的事件之后,我們看一下文本框輸入的時(shí)候會(huì)觸發(fā)的wxSearchInput方法:這個(gè)方法會(huì)首先setData文本框的值用于渲染,然后判斷this.data.id,它作為是否點(diǎn)擊回復(fù)的第一層判斷,如果this.data.id存在,我們就要判斷content是否含有"[回復(fù)XXX的評(píng)論]:",如果存在就說(shuō)明是回復(fù)評(píng)論而不是文章(我們要主要indexOf==0才算回復(fù)評(píng)論,因?yàn)樗谧钋懊娌艦閠rue,不是含有就為true)。如果不包含說(shuō)明人為的刪除了"[回復(fù)XXX的評(píng)論]:"此時(shí)我們就當(dāng)它要回復(fù)文章了,然后清除有關(guān)回復(fù)的一切數(shù)據(jù)(有個(gè)小問(wèn)題就是,我這里吧內(nèi)容全部清除了,大家可以截取一下字符串,只把[回復(fù)XX的評(píng)論]給去掉)

 wxSearchInput: function(e) {
  this.setData({
   content: e.detail.value
  })
//如果點(diǎn)擊了評(píng)論的回復(fù),this.data.id就會(huì)有值
  if (this.data.id) {
   console.log("存在點(diǎn)擊回復(fù)")
//判斷content是否含有"[回復(fù)XXX的評(píng)論]:"
   if (this.data.content.indexOf("[回復(fù)" + this.data.comment.commment[this.data.index].userName + "評(píng)論]:") == 0) {
    console.log("確定是回復(fù)評(píng)論" + this.data.comment.commment[this.data.index].userName)
   } else {
    console.log("存在點(diǎn)擊回復(fù),但是刪除了,所以是評(píng)論文章")
    //清楚有關(guān)回復(fù)的一切數(shù)據(jù)
    this.setData({
     id: "",
     content: "",
     comorfeed: "評(píng)論文章",
     insertorfeed: "發(fā)表",
    })
   }
  } else {
   console.log("不存在點(diǎn)擊回復(fù),直接評(píng)論文章")
  }
 
 },

因?yàn)槲覀冊(cè)谳斎氲臅r(shí)候就做了一系列的判斷,所以當(dāng)我們提交的時(shí)候就非常容易了:首先判斷內(nèi)容是否為空,然后通過(guò)判斷comorfeed來(lái)判定是回復(fù)文章還是回復(fù)評(píng)論。如果是回復(fù)評(píng)論那么我們提交之前應(yīng)該把文本的前綴去掉

/**
  * 用戶提交內(nèi)容,獲取用戶信息
  */
 onGotUserInfo: function(e) {
  console.log("xxx1")
  /** 
   * 檢查評(píng)論內(nèi)容是否為空
   */
  if (!this.checkContent(this.data.content)) {
   return;
  }
  /** 
   * 如果用戶授權(quán),則能拿到數(shù)據(jù),否則就是用戶拒絕授權(quán),那么提示無(wú)法評(píng)論
   */
  if (e.detail.userInfo) {
   if (this.data.comorfeed == "評(píng)論文章") {
    //發(fā)表評(píng)論
    console.log(this.data.comorfeed)
    allReq.userLogin(e.detail.userInfo.nickName, e.detail.userInfo.avatarUrl, e.detail.userInfo.gender, this.data.content, this.data.artilceId, 0);
   } else {
    console.log("回復(fù)評(píng)論")
    console.log(this.data.id)
    var co = this.data.content.split("[回復(fù)" + this.data.comment.commment[this.data.index].userName + "評(píng)論]:");
    console.log(co)
    allReq.userLogin(e.detail.userInfo.nickName, e.detail.userInfo.avatarUrl, e.detail.userInfo.gender, co[1], this.data.artilceId, this.data.id);
   }
   this.setData({
    content: "",
    id: "",
    comorfeed: "評(píng)論文章",
    insertorfeed: "發(fā)表",
   })
  } else {
   remind.modal("提示", '讓小每認(rèn)識(shí)你之后才能評(píng)論哦')
  }
 },

其實(shí)實(shí)現(xiàn)聚焦不難,有API我們很容易實(shí)現(xiàn),有點(diǎn)麻煩的是一系列的判斷,因?yàn)榧热挥玫搅司劢鼓敲纯隙ú粏螁沃皇抢疰I盤那么簡(jiǎn)單你最終要實(shí)現(xiàn)的東西肯定還需要進(jìn)一步的推進(jìn),此時(shí)到底是用失焦還是想我一樣就需要你分析你的需求了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


分享名稱:詳解小程序input框失焦事件在提交事件前的處理
鏈接URL:http://weahome.cn/article/gceshh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部