微信小程序学习之数据绑定,事件绑定,事件传参与数据同步的学习记录

数据绑定,事件绑定,事件传参与数据同步

    • 1. 数据绑定
      • 1.1. 在data中定义数据
      • 1.2. 在wxml中渲染数据 (mustache语法)
    • 2. 事件绑定
      • 2.1. 事件
      • 2.2. 常用的事件
      • 2.3. 事件对象的属性列表
      • 2.4. target 和 currentTarget的区别
    • 3. 事件传参与数据绑定
      • 3.1. 在事件处理函数中给data中的数据赋值
      • 3.2. 事件传参(通过自定义属性的方式)
      • 3.3. 获取事件传递的参数值
      • 3.4. 文本框与data之间的数据同步
        • 3.4.1. input输入框事件及获取即时的输入框数据
        • 3.4.2. 文本框与data数据同步的小demo

1. 数据绑定

数据绑定的基本原则:在data中定义数据,在wxml中使用数据

1.1. 在data中定义数据

在data中定义数据,找到页面对应的.js文件,然后把数据定义到data中即可。

pages/list/list.js

// pages/list/list.js
Page({/*** 页面的初始数据*/data: {// 字符串类型的数据、info:'init data',// 数组类型的数据msgList:[{msg:'hello'},{msg:'world'}],numberA:Math.random()*10,ImageSrc:'./kl.jpg'},//.....
})

1.2. 在wxml中渲染数据 (mustache语法)

mustache语法,插值表达式
将data中的数据绑定到页面中渲染,使用mustache语法即双大括号{{}}将变量包起来即可。
{{要绑定的数据名称}}

mustache语法可以动态的绑定内容和属性,例如:

<!-- 将当前页面的.js文件中的data中的info属性取出来 -->
<view>{{info}}</view>
<!-- 将当前页面中的.js文件中的data中的ImageSrc属性取出来-->
<image src="{{ImageSrc}}"></image>

mustache语法,还可以做一些基础的运算加减乘除,以及三元表达式

<view>{{3+2}}</view>
<view>{{3-2}}</view>
<view>{{3*2}}</view>
<view>{{3/2}}</view>
<view>{{3>2 ? '3大于2' : '3小于2'}}</view>
<view>{{numberA}}</view>
<view>{{numberA>5 ? '大于5' : '小于5'}}</view>

在这里插入图片描述

2. 事件绑定

2.1. 事件

事件即从渲染层到逻辑层的通信方式。通俗的说就是你在前台页面做了什么,需要触发哪些行为。

在这里插入图片描述

2.2. 常用的事件

类型绑定方式事件描述
tapbindtap 或 bind:tap手指触摸后马上离开,类似HTML中的click事件
inputbindinput 或 bind:input文本框的输入事件
changebindchange 或 bind:change状态改变时触发

2.3. 事件对象的属性列表

当事件回调触发时,会收到一个事件对象event

list.wxml

<view><!-- 为button按钮绑定一个tap事件,且事件名叫btnTapHandler --><button type="primary" bindtap="btnTapHandler"></button>
</view>

list.js

// pages/list/list.js
Page({/*** 页面的初始数据*/data: {//......},// 绑定的事件函数  且将event对象传入,并且在控制台打印输出btnTapHandler(e){console.log(e)},
})

控制台输出:

在这里插入图片描述

属性列表如下:

属性类型说明
tyreString事件类型
timeStampInteger页面打开到触发事件所经过的毫秒数
targetObject触发事件的组件的一些属性值集合
currentTargetObject当前组件的一些属性值集合
detailObject额外的信息
touchesArray触摸事件,当前停留在屏幕中的触摸点信息的数组
changedTouchesArray触摸事件,当前变化的触摸点信息的数组

2.4. target 和 currentTarget的区别

target 是触发该事件的源头组件,curretTarget是当前事件绑定的组件。
例如下面的例子:

list.wxml

<view style="background-color:lightgreen;" bindtap="outerHandler"><button type="primary">按钮</button><text>文字</text>
</view>

list.js

// pages/list/list.js
Page({/*** 页面的初始数据*/data: {//......},// 绑定的事件函数  且将event对象传入,并且在控制台打印输出outerHandler(e){console.dir(e.target)console.dir(e.currentTarget)},
})

在这里插入图片描述

  1. 当我们尝试点击(触摸按钮时),会输出下面的内容
    在这里插入图片描述

  2. 我们触摸text组件时,会输出下面的内容
    在这里插入图片描述

  3. 触摸view组件时,输出下面的内容
    在这里插入图片描述

对比得出,e.target就是你触摸的组件,e.currentTarget就是你当前事件绑定的组件(view)
点击内部的按钮时,点击事件以冒泡的方式向外扩散,也会触发外层view的tap事件处理函数。

3. 事件传参与数据绑定

事件传参与数据绑定几乎和vue差不多

3.1. 在事件处理函数中给data中的数据赋值

例如:点击一个按钮,将data中的某个数值加一,同时页面中的数据也通过插值表达式动态渲染出来并且实时变化。

list.wxml

<view><text style="text-align: center;margin-left: 100px;">{{count}}</text><button bindtap="countAdd" type="primary">点我+1</button>
</view>

list.js

// pages/list/list.js
Page({/*** 页面的初始数据*/data: {count:0},countAdd(){this.setData({count:this.data.count+1})},//....
)}

在这里插入图片描述

3.2. 事件传参(通过自定义属性的方式)

在微信小程序绑定事件时,绑定的是事件名,所以无法通过绑定事件时传递参数,但是可以通过自定义属性来传递参数 data-* 的方式

错误的事件传参

<button bindtap="btnTapHandler(123)">点我传递参数</button>

上面的这种写法,会让微信小程序误以为 “btnTapHander(123)” 是一个函数名,从而去该页面所在的.js文件中查找是否存在 名为 “btnTapHander(123)” 的函数。

正确的事件传参:

<!-- data-* *是data中存在的数据名 {{123}} 将被解析为数字123,即参数的值 -->
<button bindtap="btnTapHandler" data-number="{{123}}">点我传递参数</button>

3.3. 获取事件传递的参数值

在事件处理函数中,通过event.target.dataset.参数名即可获取具体的参数值。

例如,获取上面的按钮传递过来名为number的参数值

btnTapHandler(e){// e 为事件对象// dataset 也是一个对象,包含了所有通过data-* 传递过来的参数console.log(e.target.dataset)// 获取自定义属性number的值console.log(e.target.dataset.number)
}

在这里插入图片描述

3.4. 文本框与data之间的数据同步

3.4.1. input输入框事件及获取即时的输入框数据

input 输入框 的事件可以通过bindinput来绑定,然后数据获取则通过函数回调event对象,再通过event.detail.value来获取输入框即时的数据。

事件绑定 (list.wxml)

<view><!-- 注意事件名别和内置的函数名重名 --><input bindinput="inputHandlerA"/>
</view>

数据获取 (list.js)

inputHandlerA(e){console.log(e.detail.value)
}

在这里插入图片描述

在这里插入图片描述

3.4.2. 文本框与data数据同步的小demo

例子:input输入框输入数据,页面同时刷新,输入框也刷新

  1. 定义数据 (list.js)
Page({data: {msg:'你好!'},
})
  1. 渲染结构 (list.wxml)
<view><text>{{msg}}</text><input value="{{msg}}" bindinput="inputHandlerA"/>
</view>
  1. 美化样式 (list.wxss)
/* pages/list/list.wxss */
input{border: 1px solid #eee;padding: 5px;margin: 5px;border-radius: 3px;
}
text{padding: 5px;margin: 5px;border-radius: 3px;
}
  1. 绑定input事件处理函数 (list.js)
 inputHandlerA(e){this.setData({msg:e.detail.value})},

默认效果:
在这里插入图片描述

尝试输入或者删除重新输入的效果:
在这里插入图片描述

效果验证,数据同步即时刷新


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/18473.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

订单结算页+下单业务

一、订单结算页 1.业务分析 (1) 获取用户收货地址信息 一般的收货地址都是多个&#xff0c;使用时选中一个&#xff0c;所以收货地址使用List集合封装 (2)获取购物车商品信息 购物车商品也是多个&#xff0c;使用List集合封装 (3)查询商品库存 查询每个商品是否有库存&#…

Scrap爬虫框架集成Selenium来解析动态网页

1、爬虫项目单独使用scrpay框架的不足 当前网站普遍采用了javascript 动态页面&#xff0c;特别是vue与react的普及&#xff0c;使用scrapy框架定位动态网页元素十分困难&#xff0c;而selenium是最流行的浏览器自动化工具&#xff0c;可以模拟浏览器来操作网页&#xff0c;解…

spring boot MySQL操作

极简spring boot MySQL测试 默认: spring boot环境已经搭好,可以跑最基本的hello world 有MySQL环境有部分测试数据表,并且有MySQL语法基础 配置 application.yml 如下配置,根据自己的数据库信息与个人需求配置 server: tomcat: uri-encoding: UTF-8 threads: …

使用Feign进行微服务之间的接口调用:Spring Cloud Alibaba中的声明式服务调用

一、Feign介绍 Feign是一个声明式的HTTP客户端框架&#xff0c;用于简化微服务架构中服务之间的通信。它是Spring Cloud框架的一部分&#xff0c;旨在提供一种优雅且易于使用的方式来定义和调用HTTP请求。 Feign的设计目标是让服务之间的通信变得更加简单和直观。通常情况下&am…

数据结构中队列的操作方式,一目了然

队列的概念 首先我们联想一下链表&#xff0c;在单链表中&#xff0c;我们只能对他的链表表尾进行插入&#xff0c;对链表的表头进行结点的删除&#xff0c;这样强限制性的链表&#xff0c;就是我们所说的队列。 也就是说&#xff0c;队列&#xff08;queue&#xff09;是限定…

代码随想录算法训练营第十二天 | 二叉树系列3

二叉树系列3 二叉树 看到二叉树就想到递归404 左叶子之和重点代码随想录的代码我的代码(当日晚上自己理解后写) 513 找树左下角的值重点代码随想录的代码我的代码(当日晚上自己理解后写)我去&#xff0c;我怎么能写出这样的代码&#xff0c;没有return的递归&#xff0c;大错特…

在Visual Studio Code里导出8266固件

1.编辑 .vscode目录下 arduion.json 添加 一个配置项output即输出目录.当然你不设置其它软固件一样会生成,只是就不知道你能不能找到了.我的配置如下 当然这个路径你想写什么 就是什么 . 2. 切换到 arduion的项目文件 xxxx.ino.点击vsc右上的验证 即可在上面设置的目录下找到…

Java面试题大全(2023牛客网最新版)大厂面试题附答案详解

很多 Java 工程师的技术不错&#xff0c;但是一面试就头疼&#xff0c;10 次面试 9 次都是被刷&#xff0c;过的那次还是去了家不知名的小公司。 问题就在于&#xff1a;面试有技巧&#xff0c;而你不会把自己的能力表达给面试官。 应届生&#xff1a;你该如何准备简历&#…

IntegrityError: FOREIGN KEY constraint failed解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

阿里云AliYun物联网平台使用-申请免费试用及完成初始配置

一、项目简介 本专栏文章将围绕阿里云物联网平台&#xff0c;实现其设备向云平台的数据上传&#xff0c;客户端获取云平台数据。设备通过NBIOT技术实现无线采集&#xff0c;定时上传。 二、阿里云平台申请 阿里云物联网平台试用申请地址 进入上述超链接网址&#xff1a; 由于是…

This application failed to start?

大家好&#xff0c;最近在搞一个定制的图像分割项目&#xff0c;其中需要自己构建数据集。 这里我用到了基于paddle开发高效智能的交互式分割标注软件 EISeg(Efficient Interactive Segmentation)。 它涵盖了通用、人像、遥感、医疗、视频等不同方向的高质量交互式分割模型。另…

Linux安装配置Oracle+plsql安装配置(详细)

如果觉得本文不够详细&#xff0c;没有效果图&#xff0c;可移步详细版&#xff1a; Linux安装配置Oracleplsql安装配置&#xff08;超详细&#xff09;_超爱慢的博客-CSDN博客 目录 1.安装虚拟机系统 1.安装虚拟机 2.配置虚拟机 1.设置机器名 2.修改域名映射 3.固定IP…