微信小程序开发系列(十九)·wxml语法·setData()修改数据

2024-03-06 06:44

本文主要是介绍微信小程序开发系列(十九)·wxml语法·setData()修改数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

步骤一:创建一个data对象

步骤二:双大括号写法的使用

步骤三:创建一个更新事件按钮

步骤四:定义事件处理函数·获取数据

步骤五:定义事件处理函数·修改数据

方法一:通过赋值的方式直接修改数据 

方法二:通过setData()方法

总结


        小程序中修改数据不推荐通过赋值的方式进行修改,通过赋值的方式修改数据无法改变页面的数据,而是要通过调用setData()方法进行修改,setData()方法接收对象作为参数,key是需要修改的数据,value是最新的值。

setData()方法有两个作用:

1.  更新数据

2.  驱动视图更新

步骤一:创建一个data对象

        找到index.js文件,将page内的代码删除,创建一个 data 对象:


Page({data:{num: 1}
}) 

步骤二:双大括号写法的使用

        找到index.wxml文件,将其内容删除,编写代码:

<view>{{ num }}</view>

步骤三:创建一个更新事件按钮

        在index.wxml创建一个更新事件:

<button bind:tap="updateNum">更新 num</button>

步骤四:定义事件处理函数·获取数据

        可以通过this获取数据:


Page({data:{num: 1},// 更新 numupdateNum(){// 获取数据console.log(this.data.num)}
}) 

步骤五:定义事件处理函数·修改数据

方法一:通过赋值的方式直接修改数据 
  // 通过赋值的方式直接修改数据this.data.num += 1console.log(this.data.num)

        可以看出这种方法能够修改数据,但是不能改变页面上的数据:

完整代码:


Page({data:{num: 1},// 更新 numupdateNum(){// 获取数据// console.log(this.data.num)// 通过赋值的方式直接修改数据this.data.num += 1console.log(this.data.num)//能够修改数据,但是不能改变页面上的数据}
}) 
方法二:通过setData()方法

        通过调用setData()方法进行修改,setData()方法接收对象作为参数,key是需要修改的数据,value是最新的值。

  this.setData({// key:是需要更新的数据// value:是最新的值num: this.data.num + 1})console.log(this.data.num)

        可以发现此时既能够修改数据,也能改变页面上的数据:

此时代码:


Page({data:{num: 1},// 更新 numupdateNum(){// 获取数据// console.log(this.data.num)// 通过赋值的方式直接修改数据// this.data.num += 1// console.log(this.data.num)//能够修改数据,但是不能改变页面上的数据// setData()方法有两个作用:// 1.  更新数据// 2.  驱动视图更新this.setData({// key:是需要更新的数据// value:是最新的值num: this.data.num + 1   })console.log(this.data.num)}
}) 

总结

        微信小程序中的setData()方法用于修改页面数据并实时更新视图,是实现动态数据绑定的重要方法之一。当数据发生变化时,可以通过调用setData()方法来更新页面上相应的数据,并自动触发视图的更新,以确保用户界面与最新的数据保持同步。

        使用setData()方法需要传入一个对象,该对象包含需要更新的数据字段及其对应的数值。当调用setData()方法后,页面上绑定了被修改数据的部分将会自动更新,反映最新的数据状态。

        在微信小程序中,使用setData()方法修改对象数据类型是一种常见的操作,可以实现动态更新页面上展示的对象数据。当页面需要展示对象类型的数据,并且该对象的属性值可能会发生变化时,就可以通过setData()方法来更新对象数据。

具体而言,通过setData()方法可以实现以下操作:

  1. 更新对象的特定属性: 可以通过指定对象属性的路径来更新对象中的特定属性。例如,使用this.setData({'person.name':'Bob'}) 可以更新对象中的name属性为'Bob'。

  2. 替换整个对象: 除了更新单个属性外,也可以通过直接替换整个对象来更新对象数据。例如,使用 this.setData({person:{ name : 'Charlie', age: 35, gender: 'male'}})可以替换整个person对象。

  3. 触发视图更新: 调用setData()方法后,会自动触发页面视图的更新,确保页面上展示的数据与最新的对象数据保持同步。

微信小程序开发_时光の尘的博客-CSDN博客

这篇关于微信小程序开发系列(十九)·wxml语法·setData()修改数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/779159

相关文章

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片