小程序的数据绑定和事件绑定

小程序的数据绑定

1.需要渲染的数据放在index.js中的data里

复制代码
Page({
  data: {
    info:'HELLO WORLD',
    imgSrc:'/images/1.jpg',
    randomNum:Math.random()*10,
    randomNum1:Math.random().toFixed(2)
  },
})

2.在WXML中通过{{}}获取数据

复制代码
 <view>{{info}}</view>
 <image src="{{imgSrc}}" mode="widthFix"></image>
 <view>{{randomNum >= 5 ? '大于等于5' : '小于5'}}</view>
 <view>{{randomNum1 * 100}}</view>

小程序的事件绑定

什么是事件:渲染层到逻辑层的通讯方式,将用户在渲染层的行为传递到逻辑层

常见的事件

  • tap(触摸后离开)
  • input(文本框输入)
  • change(状态改变)

通过bind来绑定事件

复制代码
bindtap/bind:tap

事件对象的属性列表

事件回调触发时,会收到一个事件对象event,它的属性如下所示

|----------------|----------------------------|
| type | 事件类型 |
| timeStamp | 页面打开到触发事件所用的毫秒数 |
| target | 触发事件的组件的一些属性值集合(触发事件的源头组件) |
| currentTarget | 当前组件的一些属性值集合(正在触发事件的组件) |
| detail | 额外的信息 |
| touches | 触摸事件,当前停留在屏幕上触摸点信息的数组 |
| changedTouches | 触摸事件,当前变化的触摸点信息的数组 |

1.给组件绑定事件

复制代码
<button type="primary" bindtap="btnHandler">按钮</button>

2.点击组件触发的事件

复制代码
Page({ 
  btnHandler(e){
     console.log(e)
  }
})

3.查看绑定的效果

将事件绑定的数据进行渲染并且同步(vue的v-model事件)

1.创建一个共享的数据

复制代码
Page({ 
  data:{ 
    msg:"你好"
  }, 

}) 

2.将input组件绑定一个事件 syn并渲染数据

{{}} 获取数据

复制代码
<input value="{{msg}}" bindinput="syn"/>

3.在js中编写syn的事件,将数据进行同步

this.setData 给数据重新进行赋值

复制代码
Page({ 
  data:{ 
    msg:"你好"
  }, 
  syn(e){
   this.setData({
     msg: e.detail.value
   })
  }
})

相关推荐
小徐_23338 小时前
uni-app 组件库 Wot UI 2.0 发布了,我们带来了这些改变!
前端·微信小程序·uni-app
Greg_Zhong9 小时前
微信小程序中实现自定义颜色选择器(简陋版对比精致版)
微信小程序·自定义颜色选择器面板
杰建云16710 小时前
2026年第三方平台制作微信小程序多少钱?
微信小程序·小程序·小程序制作
vipbic1 天前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序
全栈小52 天前
【小程序】微信小程序在体验版发起支付的时候提示“由于小程序违规,支付功能暂时无法使用”,是不是一脸懵逼
微信小程序·小程序
jingqingdai32 天前
微信小程序 Canvas 2D 踩坑指南:如何优雅地导出高清长图?(附 AI 辅助实录)
人工智能·微信小程序·小程序
qq_433502182 天前
微信小程序更新机制踩坑记录:updateInfo 为什么总是读到旧数据?
微信小程序·小程序·notepad++
QQ22792391023 天前
Java springboot基于微信小程序的智慧旅游导游系统景点门票酒店预订(源码+文档+运行视频+讲解视频)
java·spring boot·微信小程序·maven·vuejs
笨笨狗吞噬者4 天前
uni-app 运行时揭秘:styleIsolation 的转化
前端·微信小程序·uni-app
double_eggm4 天前
微信小程序3
微信小程序·小程序