小程序基礎(chǔ)數(shù)據(jù)綁定蚯根,事件綁定

數(shù)據(jù)綁定

3.1 了解數(shù)據(jù)綁定的原則
  1. 數(shù)據(jù)綁定的基本原則

    • data 中定義數(shù)據(jù)

    • wxml 中使用數(shù)據(jù)

  2. data 中定義頁面的數(shù)據(jù)

    在頁面對應(yīng)的 .js 文件中即硼,把數(shù)據(jù)定義在 data 對象中即可:

    image.png

  1. Mustache 語法的格式

    data 中的數(shù)據(jù)綁定到頁面中渲染,使用 Mustache 語法 (雙大括號) 將變量包起來即可。語法格式如下

    image.png

  1. 案例代碼
data: {
  name: 'xiaomi'
}
<view>{{ name }}</view>
3.2 動(dòng)態(tài)綁定屬性
  1. Mustache 語法的應(yīng)用場景

    • 綁定內(nèi)容

    • 綁定屬性

    • 運(yùn)算(三元運(yùn)算谷饿、算術(shù)運(yùn)算符)

  2. 動(dòng)態(tài)綁定內(nèi)容

    頁面的數(shù)據(jù)如下:


    image.png

頁面的結(jié)構(gòu)如下:

image.png
  1. 動(dòng)態(tài)綁定屬性

    頁面的數(shù)據(jù)如下:


    image.png

頁面的結(jié)構(gòu)如下:

image.png
  1. 案例代碼
data: {
  imgSrc: 'http://www.itcast.cn/2018czgw/images/logo.png'
}
<image src="{{ imgSrc }}" mode="widthFix"></image>
3.3 三元運(yùn)算

頁面的數(shù)據(jù)如下

image.png

頁面的結(jié)構(gòu)如下


image.png

案例代碼

data: {
  randomNum: Math.random() * 10 // 生成 10 以內(nèi)的隨機(jī)數(shù)
}
<view>{{ randomNum >= 5 ? '隨機(jī)數(shù)字大于或等于5' : '隨機(jī)數(shù)小于 5' }}</view>
3.4 算數(shù)運(yùn)算

頁面的數(shù)據(jù)如下

image.png

頁面的結(jié)構(gòu)如下


image.png

案例代碼

data: {
  randomNum1: Math.random().toFixed(2)
}
<view>{{ randomNum1 * 100 }}</view>

4. 事件綁定

4.1 了解什么是事件以及小程序中常用的事件
  1. 什么是事件

    事件是渲染層到邏輯層的通訊方式。通過事件可以將用戶在渲染成產(chǎn)生的行為妈倔,反饋到邏輯層進(jìn)行業(yè)務(wù)的處理

image.png
  1. 小程序中常用的事件

    • bindtap博投、bindinput、bindchange

    • bind:tap盯蝴、bind:input毅哗、bind:chage

    類型 綁定方式 事件描述
    tap bindtap 或 bind:tap 手指觸摸后馬上離開,類似于 HTML 中的 click 事件
    input bindinput 或者 bind:input 文本框的輸入事件
    change bindchange 或 bind:change 狀態(tài)改變時(shí)觸發(fā)
4.2 事件對象的屬性列表

當(dāng)事件回調(diào)觸發(fā)的時(shí)候捧挺,會(huì)收到一個(gè)事件對象 event虑绵,它的詳細(xì)屬性如下

屬性 類型 說明
type String 事件類型
timeStamp Integer 事件生成時(shí)的時(shí)間戳
target Object 觸發(fā)事件的組件的一些屬性值集合
currentTarget Object 當(dāng)前組件的一些屬性值集合
detail Object 額外的信息
touches Array 觸摸事件,當(dāng)前停留在屏幕中的觸摸點(diǎn)信息的數(shù)組
changedTouches Array 觸摸事件闽烙,當(dāng)前變化的觸摸點(diǎn)信息的數(shù)組
4.3 target 和 currentTarget 的區(qū)別
  1. target 是觸發(fā)該事件的源頭組件

  2. currentTarget 則是當(dāng)前事件所綁定的組件

    image.png

點(diǎn)擊內(nèi)部的按鈕時(shí)翅睛,點(diǎn)擊事件以 冒泡 的方式向外擴(kuò)散,也會(huì)觸發(fā)外層 viewtap 事件處理程序

此時(shí)黑竞,對于外層的 view 來說:

  1. e.target 指定的是觸發(fā)事件的源頭組件捕发,因?yàn)?e.target 是內(nèi)部的按鈕組件

  2. e.currentTarget 指向的是當(dāng)前正在觸發(fā)事件的那個(gè)組件,因此 e.currentTarget 是當(dāng)前的 view 組件

4.4 bindTap 的語法格式

在小程序中很魂,不存在 HTML 中的 onclick 鼠標(biāo)點(diǎn)擊事件扎酷,而是通過 tap 事件來響應(yīng)用戶的觸摸行為

  1. 通過 bindtap,可以為組件綁定 tap 觸摸事件
image.png
  1. 在頁面的 .js 文件中定義對應(yīng)的事件處理函數(shù)遏匆,事件參數(shù)通過形參 event(一般簡寫為 e) 來接收
image.png

案例代碼

// 按鈕 tap 事件處理函數(shù)
btnTapHandle (e) {
  // 事件參數(shù)對象 e
  console.log(e)
}
<view>
  <button type="primary" bindtap="btnTapHandle">按鈕</button>
</view>
4.5 在事件處理函數(shù)中為 data 中的數(shù)據(jù)賦值

通過調(diào)用 this.setData(dataObject) 方法法挨,可以給頁面 data 中的數(shù)據(jù)重新賦值

image.png

案例代碼:

// count 值 + 1 處理
changeCount () {
  this.setData({
    count: this.data.count + 1
  })
}
<view>
  <button type="primary" bindtap="changeCount">+ 1</button>
</view>
4.6 事件傳參
  1. 事件傳參錯(cuò)誤方式

    小程序中的事件傳參比較特殊,不能在綁定事件的同時(shí)為事件處理程序傳遞參數(shù)幅聘,例如凡纳,下面的代碼將不能正常工作

    因?yàn)樾〕绦驎?huì)把 bindtap 的屬性值,統(tǒng)一當(dāng)作事件名稱來處理喊暖,相當(dāng)于要調(diào)用一個(gè)名稱為 btnHandler(123) 的事件處理函數(shù)

image.png
  1. 事件傳參正確的方式

    可以為組件提供 data-* 自定義屬性傳參惫企,其中 * 代表的是參數(shù)的名字撕瞧,實(shí)例代碼如下:

    最終:

    • info 會(huì)被解析為 參數(shù)的名字

    • 數(shù)值 2 會(huì)被解析為 參數(shù)的值

image.png
  1. 接收事件傳遞的參數(shù)

    在事件處理函數(shù)中陵叽,通過 event.target.dataset.參數(shù)名 即可獲取到具體參數(shù)的值狞尔,示例代碼如下:

image.png
  1. 案例代碼
data: {
  count: 0
}
// count 值 + 2 處理
bindTap2 (e) {
  this.setData({
    count: this.data.count + e.target.dataset.num
  })
}
<view>
  <button type="primary" bindtap="bindTap2" data-num="{{ 2 }}">+ 2</button>
</view>
4.7 bindinput 的語法格式

在小程序中,通過 input 事件來響應(yīng)文本框的輸入事件巩掺,語法格式如下:

  1. 通過 bindinput偏序,可以為為文本框綁定輸入事件


    image.png
  1. 在頁面的 .js 文件中定義事件處理函數(shù)
image.png
  1. 案例代碼
// 獲取 input 中的最新輸入的數(shù)據(jù)
inputHandle (e) {
  // e.detail.value 是輸入框最新輸入的值
  console.log(e.detail.value)
}
<view>
  <input type="text" bindinput="inputHandle" />
</view>
4.8 實(shí)現(xiàn)文本框和 data 之間的數(shù)據(jù)同步
  1. 定義數(shù)據(jù)
image.png
  1. 渲染結(jié)構(gòu)


    image.png
  1. 美化樣式
image.png
  1. 綁定 input


    image.png
  1. 案例代碼
<view>
  <input value="{{ msg }}" bindinput="setMsg" />
</view>
data: {
  msg: ``
}
// 實(shí)現(xiàn)文本框和 data 之間數(shù)據(jù)的同步
setMsg (e) {
  this.setData({
    msg: e.detail.value
  })
}
input {
  border: 1px solid lightcoral;
  padding: 5px;
  margin: 5px;
  border-radius: 3px;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市胖替,隨后出現(xiàn)的幾起案子研儒,更是在濱河造成了極大的恐慌,老刑警劉巖独令,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件端朵,死亡現(xiàn)場離奇詭異,居然都是意外死亡燃箭,警方通過查閱死者的電腦和手機(jī)冲呢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來招狸,“玉大人敬拓,你說我怎么就攤上這事∪瓜罚” “怎么了乘凸?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長累榜。 經(jīng)常有香客問我营勤,道長,這世上最難降的妖魔是什么信柿? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任冀偶,我火速辦了婚禮,結(jié)果婚禮上渔嚷,老公的妹妹穿的比我還像新娘进鸠。我一直安慰自己,他們只是感情好形病,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布客年。 她就那樣靜靜地躺著,像睡著了一般漠吻。 火紅的嫁衣襯著肌膚如雪量瓜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天途乃,我揣著相機(jī)與錄音绍傲,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛烫饼,可吹牛的內(nèi)容都是我干的猎塞。 我是一名探鬼主播,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼杠纵,長吁一口氣:“原來是場噩夢啊……” “哼荠耽!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起比藻,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤铝量,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后银亲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體慢叨,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年务蝠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了插爹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,615評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡请梢,死狀恐怖赠尾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情毅弧,我是刑警寧澤气嫁,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站够坐,受9級特大地震影響寸宵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜元咙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一梯影、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧庶香,春花似錦甲棍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至奢赂,卻和暖如春陪白,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背膳灶。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工咱士, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓序厉,卻偏偏與公主長得像拆吆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子脂矫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評論 2 359

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