官网传送门
WXML 中的动态数据均来自对应 Page 的 data。
数据绑定使用 Mustache
语法(双大括号)将变量包起来
ts
Page({
data: {
info: 'hello wechart!',
msgList: [{ msg: 'hello' }, { msg: 'wechart' }]
},
})
WXML
<view class="view-container">
<view>
<text>{{info}}text>
view>
view>
Mustache语法应用场景
注:微信小程序数据绑定与vue2的语法相同
官网传送门
常用事件
类型 | 绑定方式 | 事件描述 |
---|---|---|
tap | bindtap或bind:tap | 触摸之后马上离开,类似html中click事件 |
input | bindinput或bind:input | 文本框输入事件 |
change | bindchange或bind:change | 状态改变时触发事件 |
事件回调对象event属性列表
属性 | 类型 | 说明 |
---|---|---|
type | String | 事件类型 |
timeStamp | integer | 页面打开到触发事件经过的毫秒数 |
target | Object | 触发事件的组件的属性值集合 |
currentTarget | Object | 当前组件的属性值集合 |
detail | Object | 额外的信息 |
toches | Array | 触摸事件,当前停留在屏幕中的触摸点信息的数组 |
changedToches | Array | 触摸事件,当前变化的触摸点信息的数组 |
WXML
<view>
<button bind:tap="btnTapHandler">Clickbutton>
view>
ts
Page({
btnTapHandler(event: WechatMiniprogram.BaseEvent){
console.log(event)
}
})
<view>
<text>{{count}}text>
view>
<view>
<button bind:tap="addCount">Addbutton>
view>
ts
Page({
data: {
count: 0
},
addCount() {
this.setData({
count: this.data.count + 1
})
},
})
事件传参
通过属性data-info
给函数传递参数, e.target.dataset.info
获取参数
例:点击add+2,count自增2
WXML
<view>
<text>{{count}}text>
view>
<view>
<button bind:tap="addDoubleCount" data-info="{{2}}">Add+2button>
view>
ts
Page({
data: {
count: 0
},
addDoubleCount(e: WechatMiniprogram.BaseEvent) {
this.setData({
count: this.data.count + e.target.dataset.info
})
},
})
WXML
<view>
<text>{{info}}text>
view>
<view>
<input bindinput="inputHandler" />
view>
ts
Page({
data: {
info: 'hello wechart!'
},
inputHandler(e: WechatMiniprogram.CustomEvent) {
this.setData({
info: e.detail.value
})
},
})
WXML
<view>
<switch checked="{{checked}}" bindchange="switchChange"/>
view>
<view wx:if="{{checked}}">
Block
view>
<view wx:else>
UnBlock
view>
ts
Page({
data: {
checked: true,
},
switchChange(e: WechatMiniprogram.CustomEvent) {
this.setData({
checked: e.detail.value
})
},
})
官网传送门
在组件上使用 wx:for
控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。
默认数组的当前项的下标变量名默认为 index
,数组当前项的变量名默认为 item
<view wx:for="{{msgList}}">
{{index}}: {{item.msg}}
view>
Page({
data: {
msgList: [{ msg: 'hello' }, { msg: 'wechart' }]
}
})
使用 wx:for-item
可以指定数组当前元素的变量名,
使用 wx:for-index
可以指定数组当前下标的变量名:
<view wx:for="{{msgList}}" wx:for-index="idx" wx:for-item="itemName">
{{idx}}: {{itemName.message}}
view>
在小程序官网 开发管理 ->开发配置 ->服务器域名配置合法域名
可以在开发工具详情查看配置的域名
get
wx.request({
url: 'https://www.***.cn/api/get',
method: 'GET',
data: {
name: 'zs',
},
success: (res) => {
console.log(res);
}
})
post
wx.request({
url: 'https://www.***.cn/api/post',
method: 'POST',
data: {
name: 'zs',
age: 22
},
success: (res) => {
console.log(res);
}
})