微信小程序輸入框

小程序的輸入框主要有單行輸入框 input 和多行輸入框 textarea毁腿,這兩個(gè)控件雖然看著比較簡(jiǎn)單,但使用時(shí)很容易踩到坑袱瓮,導(dǎo)致出現(xiàn)各種問(wèn)題宛瞄,比如輸入時(shí)光標(biāo)跳轉(zhuǎn)等等浮禾,這篇文章主要介紹怎么避免這些問(wèn)題。

input 和 textarea 比較常用的屬性有 placeholder份汗、placeholder-class盈电、bindinput、bindblur 杯活、value匆帚、name 等等。
placeholder 是指未輸入時(shí)顯示的提示文案旁钧,placeholder-class 則是 placeholder 的樣式吸重,可在 wxss 里面定義。
bindinput 是輸入時(shí)的回調(diào)方法均践,bindblur 是輸入完成后失去焦點(diǎn)時(shí)的回調(diào)方法晤锹,但是 textarea 的 bindblur 方法有坑摩幔,后面會(huì)講彤委。
value 是輸入框里面的文案,主要是在輸入框有初始值的時(shí)候使用或衡,也往往是引起上述問(wèn)題的原因焦影。
name 屬性主要用于表單提交時(shí),后面會(huì)講封断。

這里以輸入單行標(biāo)題和多行內(nèi)容為例子進(jìn)行說(shuō)明斯辰。

1、在新建的情況下坡疼,輸入框僅僅是用于輸入彬呻,沒(méi)有初始值,則不需要為其設(shè)置 value 屬性,不會(huì)產(chǎn)生任何問(wèn)題闸氮。
方案一:
在 js 的 data 里面定義一個(gè)字符串字段作為輸入的內(nèi)容剪况,在輸入時(shí)的回調(diào)方法 bindinput 中改變 data 里面對(duì)應(yīng)的字段,然后在點(diǎn)擊按鈕提交的時(shí)候使用該字符串作為輸入的內(nèi)容蒲跨。這里之所以不使用 bindblur 方法是因?yàn)?textarea 的坑译断,后面會(huì)講。

wxml文件:
<view>
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" bindinput="inputTitle" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" bindinput="inputContent" />
  <button bindtap="save">保存</button>
</view>

js文件:
Page({
  data: {
    title: '',
    content: ''
  },
  inputTitle: function (e) {
    this.setData({
      title: e.detail.value
    })
  },
  inputContent: function (e) {
    this.setData({
      content: e.detail.value
    })
  },
  save: function (e) {
    var title = this.data.title;
    var content = this.data.content;
    // 提交請(qǐng)求
    ...
  }
})

方案二:
采用表單提交的方式或悲,不需要在 data 中定義字段孙咪,也無(wú)需綁定 bindinput 或 bindblur 方法,只需要在輸入框中定義 name 屬性巡语,然后在表單提交的方法里面使用 e.detail.value.xxx 獲取輸入框的內(nèi)容翎蹈,其中 xxx 就是 name 對(duì)應(yīng)的字符串。

wxml文件:
<form report-submit="true" bindsubmit="save">
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" name="title" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" name="content" />
  <button class="button" form-type="submit">保存</button>
</form>

js文件:
Page({
  data: {
  },
  save: function (e) {
    var title = e.detail.value.title.trim();
    var content = e.detail.value.content.trim();
    // 提交請(qǐng)求
    ...
  }
})

2男公、在修改編輯的情況下杨蛋, 輸入框里面有初始文案,則需要將 value 設(shè)置為 data 里面對(duì)應(yīng)的字段理澎,此時(shí)如果繼續(xù)用 bindinput 修改 data 里面對(duì)應(yīng)的字段逞力,則由于每次修改時(shí)數(shù)據(jù)會(huì)更新到輸入框,導(dǎo)致光標(biāo)會(huì)跳轉(zhuǎn)到最后糠爬。

wxml文件:
<view>
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" bindinput="inputTitle" value="{{title}}" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" bindinput="inputContent" value="{{content}}" />
  <button bindtap="save">保存</button>
</view>

js文件:
Page({
  data: {
    title: '',
    content: ''
  },
  onLoad: function (opt) {
    // 設(shè)置初始值
    this.setData({
      title: opt.title,
      content: opt.content
    })
  },
  inputTitle: function (e) {
    this.setData({
      title: e.detail.value
    })
  },
  inputContent: function (e) {
    this.setData({
      content: e.detail.value
    })
  },
  save: function (e) {
    var title = this.data.title;
    var content = this.data.content;
    // 提交請(qǐng)求
    ...
  }
})

方案1:
將 bindinput 改為 bindblur寇荧,即在輸入框失去焦點(diǎn)時(shí)才改變 data 里面對(duì)應(yīng)的字段。然而當(dāng)輸入完直接點(diǎn)擊按鈕時(shí)执隧,textarea 控件的 bindblur 并不會(huì)先執(zhí)行揩抡,導(dǎo)致需要再次點(diǎn)擊按鈕才能獲取 textarea 中的真實(shí)數(shù)據(jù)《屏穑或者先點(diǎn)擊其他區(qū)域使 textarea 的 bindblur 執(zhí)行完成后峦嗤,再點(diǎn)擊按鈕提交。而 input 控件則不會(huì)有這個(gè)問(wèn)題屋摔,因此這種方案只有在單行輸入的情況下才能使用烁设。

wxml文件:
<view>
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" bindblur="blurTitle" value="{{title}}" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" bindblur="blurContent" value="{{content}}" />
  <button bindtap="save">保存</button>
</view>

js文件:
Page({
  data: {
    title: '',
    content: ''
  },
  onLoad: function (opt) {
    // 設(shè)置初始值
    this.setData({
      title: opt.title,
      content: opt.content
    })
  },
  blurTitle: function (e) {
    this.setData({
      title: e.detail.value
    })
  },
  blurContent: function (e) {
    this.setData({
      content: e.detail.value
    })
  },
  save: function (e) {
    var title = this.data.title;
    var content = this.data.content;
    // 提交請(qǐng)求
    ...
  }
})

方案2:
在 data 中為每個(gè)輸入框增加一個(gè)對(duì)應(yīng)的初始值字段,將 value 設(shè)置成該字段钓试,其他的不變装黑。這種方案能很好的解決問(wèn)題,代價(jià)也不大弓熏。

wxml文件:
<view>
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" bindinput="inputTitle" value="{{titleOrigin}}" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" bindinput="inputContent" value="{{contentOrigin}}" />
  <button bindtap="save">保存</button>
</view>

js文件:
Page({
  data: {
    titleOrigin: '',
    title: '',
    contentOrigin: '',
    content: ''
  },
  onLoad: function (opt) {
    // 設(shè)置初始值
    this.setData({
      titleOrigin: opt.title,
      contentOrigin: opt.content
    })
  },
  inputTitle: function (e) {
    this.setData({
      title: e.detail.value
    })
  },
  inputContent: function (e) {
    this.setData({
      content: e.detail.value
    })
  },
  save: function (e) {
    var title = this.data.title;
    var content = this.data.content;
    // 提交請(qǐng)求
    ...
  }
})

方案3:
采用表單提交的方法恋谭,跟之前一樣,不需要綁定 bindinput 或者 bindblur 等回調(diào)方法挽鞠,只需要在輸入框里面加上 name 屬性疚颊。

wxml文件:
<form report-submit="true" bindsubmit="save">
  <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" name="title" value="{{title}}" />
  <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" name="content" value="{{content}}" />
  <button class="button" form-type="submit">保存</button>
</form>

js文件:
Page({
  data: {
    title: '',
    content: ''
  },
  onLoad: function (opt) {
    // 設(shè)置初始值
    this.setData({
      title: opt.title,
      content: opt.content
    })
  },
  save: function (e) {
    var title = e.detail.value.title.trim();
    var content = e.detail.value.content.trim();
    // 提交請(qǐng)求
    ...
  }
})

一般來(lái)說(shuō)狈孔,如果表單提交的方法不被占用的話,推薦使用表單提交的方法材义,否則除抛,如果表單提交的方法需要用在別的地方(比如之前的文章《微信小程序消息重復(fù)推送》里面提到的postFormId)的話,則可以使用增加初始值字段的方法母截。

最后到忽,一般輸入框后面會(huì)加一個(gè)清空的圖標(biāo),在有內(nèi)容時(shí)顯示清寇,以下是基本的實(shí)現(xiàn)喘漏。

wxml文件:
<form report-submit="true" bindsubmit="save">
  <view class="info">
    <view class="info-item first title">
      <view class="label">標(biāo)題</view>
      <input type="text" placeholder="請(qǐng)輸入標(biāo)題" placeholder-class="placeholder" bindinput="inputTitle" name="title" value="{{title}}" />
      <icon class="clear" type="clear" size="15" wx:if="{{!titleEmpty}}" catchtap="clearTitle" />
    </view>
    <view class="info-item content">
      <view class="label">內(nèi)容</view>
      <textarea placeholder="請(qǐng)輸入內(nèi)容" placeholder-class="placeholder" bindinput="inputContent" name="content" value="{{content}}" maxlength="-1" auto-height="true" />
      <icon class="clear" type="clear" size="15" wx:if="{{!contentEmpty}}" catchtap="clearContent" />
    </view>
  </view>
  <button class="button" form-type="submit">保存</button>
</form>
js文件:
Page({
  data: {
    title: '',
    content: '',
    titleEmpty: true,
    contentEmpty: true
  },
  onLoad: function (opt) {
    // 設(shè)置初始值
    this.setData({
      title: opt.title,
      content: opt.content
    })
    this.setData({
      titleEmpty: util.isTextEmpty(this.data.title),
      contentEmpty: util.isTextEmpty(this.data.content)
    })
  },
  inputTitle: function (e) {
    this.setData({
      titleEmpty: e.detail.value.length == 0
    })
  },
  clearTitle: function () {
    this.setData({
      title: '',
      titleEmpty: true
    })
  },
  inputContent: function (e) {
    this.setData({
      contentEmpty: e.detail.value.length == 0
    })
  },
  clearContent: function () {
    this.setData({
      content: '',
      contentEmpty: true
    })
  },
  save: function (e) {
    var title = e.detail.value.title.trim();
    var content = e.detail.value.content.trim();
    this.setData({
      title: title,
      content: content
    })
    // 提交請(qǐng)求
    ...
  }
})
wxss文件:
.info {
  background-color: #fff;
}

.info-item {
  height: 88rpx;
  display: flex;
  display: -webkit-flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding: 0 30rpx;
  border-top: 1rpx solid #e5e5e5;
  color: #000;
  font-size: 32rpx;
}

.info-item.first {
  border: 0;
}

.content {
  height: auto;
  align-items: flex-start;
}

.label {
  flex-shrink: 0;
}

.title .label {
  width: 182rpx;
}

.content .label {
  width: 170rpx;
  padding-top: 20rpx;
}

input {
  flex-grow: 1;
}

textarea {
  flex-grow: 1;
  min-height: 150rpx;
  margin: 10rpx 70rpx 0 0;
}

.placeholder {
  color: #9a9a9a;
}

.clear {
  flex-shrink: 0;
  padding: 20rpx;
}

.button {
  margin-top: 20rpx;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市华烟,隨后出現(xiàn)的幾起案子翩迈,更是在濱河造成了極大的恐慌,老刑警劉巖盔夜,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件负饲,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡喂链,警方通過(guò)查閱死者的電腦和手機(jī)返十,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)椭微,“玉大人洞坑,你說(shuō)我怎么就攤上這事∮剩” “怎么了迟杂?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)本慕。 經(jīng)常有香客問(wèn)我排拷,道長(zhǎng),這世上最難降的妖魔是什么锅尘? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任监氢,我火速辦了婚禮,結(jié)果婚禮上鉴象,老公的妹妹穿的比我還像新娘忙菠。我一直安慰自己,他們只是感情好纺弊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著骡男,像睡著了一般淆游。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天犹菱,我揣著相機(jī)與錄音拾稳,去河邊找鬼。 笑死腊脱,一個(gè)胖子當(dāng)著我的面吹牛访得,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播陕凹,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼悍抑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了杜耙?” 一聲冷哼從身側(cè)響起搜骡,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎佑女,沒(méi)想到半個(gè)月后记靡,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡团驱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年摸吠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嚎花。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蜕便,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贩幻,到底是詐尸還是另有隱情轿腺,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布丛楚,位于F島的核電站族壳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏趣些。R本人自食惡果不足惜仿荆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坏平。 院中可真熱鬧拢操,春花似錦、人聲如沸舶替。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)顾瞪。三九已至舔庶,卻和暖如春抛蚁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背惕橙。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工瞧甩, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人弥鹦。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓肚逸,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親彬坏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子朦促,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • React中沒(méi)有類(lèi)似Angular那樣的雙向數(shù)據(jù)綁定思灰,在做一些表單復(fù)雜的后臺(tái)類(lèi)頁(yè)面時(shí),監(jiān)聽(tīng)混滔、賦值洒疚、傳遞、校驗(yàn)時(shí)編碼...
    tedyuen777閱讀 9,866評(píng)論 1 23
  • 表單基礎(chǔ)知識(shí) 在HTML中坯屿,表單是由 元素來(lái)表示的油湖,而在JS中,表單對(duì)應(yīng)的則是HTMLFormElement類(lèi)型领跛。...
    oWSQo閱讀 909評(píng)論 0 1
  • 本人做php的,最近發(fā)現(xiàn)JS真的是博大精深啊,比PHP難.在HTML中乏德,表單是由form元素來(lái)表示的,但是在jav...
    linfree閱讀 2,155評(píng)論 3 17
  • 什么是FORM表單: 表單是用來(lái)提交資料吠昭、意見(jiàn)喊括,規(guī)范流程執(zhí)行過(guò)程的格式。表單在網(wǎng)頁(yè)中主要負(fù)責(zé)數(shù)據(jù)采集功能矢棚。一個(gè)表單...
    PYFang閱讀 1,131評(píng)論 0 0
  • 吻起您嘴唇的血 舔注紅透了的肉體 不必剝削您的全部 這夜色的溫柔 在清屋里 方桌上 用一盞古老的罩燈展開(kāi) 侵占 有...
    藍(lán)少閱讀 133評(píng)論 0 1