《微信小程序开发从入门到实战》学习十八

3.3 开发创建投票页面

3.3.5 数据的双向传递

通过上一小节的代码和预览效果可以看到使用时间函数可以将视图层传递到逻辑层。

视图层数据由小程序管理,逻辑层通常保存在data对象,必须由开发者自己管理。

微信开发工具的AppData的面板可以实时查看到页面逻辑层的数据,但只建立了单向传递。

如果希望修改页面逻辑层AppData的面板的数据,能在模拟器页面的视图层实时看到formTitle改变,

可以在input组件添加value="{{formTitle}}"

这就实现了formTitle这个数据的双向传递。

只有表单组件能实现双向传递,text这类组件不行。

双向传递可以避免视图层和逻辑层的数据修改后有显示不一致的问题。

3.3.6 textarea多行输入框组件

 使用textarea组件为创建投票页面增加一个用于填写补充描述的输入框。在createVote.wxml的input组件下面添加,代码如下:

 <textarea value="{{formDesc}}" class="form-desc" bindinput="onDescChange" auto-height placeholder="补充描述(选填)" placeholder-class="form-text-placeholder"/>

在createVote.wxss文件中为它添加如下样式代码:

.form-desc {

  margin-top: 40rpx;

  width: 100%;

  color: #333;

  font-size: 14pt;

  border-bottom: 1rpx solid #eee;

  padding: 20rpx 0;

  box-sizing: content-box;

}

.form-text-placeholder {

  color: #ccc;

}

最后修改createVote.js,增加逻辑层的数据变量的事件处理函数,代码如下:

// pages/createVote/createVote.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    formTitle: '' //用来保存当前的投票标题输入框中的内容,

    formDesc: ''

  },
  onTitleInputChange(e) {
    console.log(e.detail.value)
    this.setData({
      formTitle: e.detail.value //输入框内容改变时,立即更新data中的formTitle属性
    })
  },

  onDescChange(e){

    this.setData({

      formDesc: e.detail.value

    })

  },

  formSubmit(){
    //todo
  },
  formReset(){
    //todo
  }
})

预览效果如下:

(点完ctrl+s,右下角AppData没有出现formDesc,于是点调试器的编译上的刷新按钮,formDesc成功出现啦,双向传递也成功啦)

textArea组件属性:

value                输入框内容

placeholder      输入框为空时的提示文字

disabled            是否禁用输入框,用于展示一些用户无法改变的内容

maxlength         最大输入长度

focus                进入表单页面时自动获取焦点

auto-height       是否随内容行数增加自动增高

fixed                 如果textarea在一个position:fixed的区域,需要显示指定属性fixed为true

bindinput           键盘输入时触发的事件处理函数,有一个Object类型的event参数,保存本次事件全部信息。

bindfocus          输入框聚焦时触发的事件处理函数,有event参数

bindblur             输入框失去焦点时触发的事件处理函数,有event参数

bindconfirm       单击键盘的完成时触发的事件处理函数,有event参数

bindlinechange 输入框行数变化时触发的事件处理函数,有event参数但获取不到输入框内容,而通过event.detail.lineCount可以获取到当前输入的行数。

event参数有携带有很多信息,可以通过console.log(event)进行查看。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用 uWSGI 部署 Django 应用详解

概要 部署 Django 应用到生产环境是一个至关重要的步骤&#xff0c;其中选择合适的 WSGI 服务器对于确保应用的稳定性和性能至关重要。uWSGI 是一个流行的选择&#xff0c;它不仅高效、轻量&#xff0c;还非常灵活。本文将详细介绍如何使用 uWSGI 来部署 Django 应用&#xff…

【Linux】C文件系统详解(四)——磁盘的物理和抽象结构

文章目录 磁盘结构磁盘物理结构磁盘的具体物理结构磁盘结构的逻辑抽象 文件系统BootBlockSuperBlockGroupDescriptorTableinode tableDataBlocksinodeBitmapblockBitmaplinux中的inode 和文件名如何理解文件的增删查改删 补充细节1.如果文件误删了,我们该怎么办?2.inode确定分…

电脑监控软件都有哪些,哪款好用丨全网盘点

电脑监控软件是一种用于监视和控制计算机的软件工具&#xff0c;可以帮助企业和个人了解计算机的使用情况&#xff0c;保护数据安全&#xff0c;提高工作效率等。 电脑监控软件都有哪些&#xff1a; 1、域之盾软件 这是一款功能强大的电脑监控软件&#xff0c;可以实时监控电脑…

python绘图常见问题及解决方法总结

文章目录 1. 多个图片绘制到一起时出现title和xstick重合 1. 多个图片绘制到一起时出现title和xstick重合 fig, axes plt.subplots(6, 2, figsize(20, 40)) # Adjust the layout padding plt.subplots_adjust(hspace0.5, wspace0.4) # Plotting scatter plots for Tiu and ws_…

详解使用asyncio实现playwright并发操作(复制源码即可运行)

asyncio实现并发 我们可以使用asyncio来解决palywright中并发的问题&#xff0c;asyncio即Asynchronous I/O是python一个用来处理并发(concurrent)事件的包&#xff0c;是很多python异步架构的基础&#xff0c;多用于处理高并发网络请求方面的问题。给大家举一个经典的应用场景…

开源vs闭源大模型如何塑造技术的未来?开源模型的优劣势未来发展方向

开源vs闭源大模型如何塑造技术的未来&#xff1f;开源模型的优劣势&未来发展方向 写在最前面一、开源与闭源&#xff1a;定义与历史背景开源和闭源的定义开源大模型&#xff1a;社区驱动的创新 二、开源和闭源的优劣势比较开源大模型&#xff08;瓶颈&#xff09;数据&…

yolov8使用opencv2实时检测,两种物品,左上角显示信息

效果为&#xff1a; 左上角显示 帧率&#xff1a;FPS 序列号&#xff1a;SN 两种物品的检测数量和总数 可以应用于工业检测 import cv2 from ultralytics import YOLO from cv2 import getTickCount, getTickFrequency # 加载 YOLOv8 模型 model YOLO("weights/yolov8s.…

微信小程序云开发 微信支付功能 逻辑+踩坑

前置条件 首先开通微信支付商户号 然后小程序后台里关联商户号 然后在开发者工具里申请api权限 云开发》设置》其他设置》微信支付配置 申请一下权限和绑定 显示已通过即可。 逻辑 首先用户点击支付按钮&#xff0c;就会触发unlock() 在unlock函数中创建新订单&#xff…

iOS自动化测试方案(五):保姆级VMware虚拟机安装MacOS

文章目录 一、前言二、VMwareMacOS镜像2.1、先下载vmware-workstation2.2、再下载macOS Big Sur(11.6) 三、图解安装过程3.1、双击VMware-WorkStation Pro图标 四、总结 一、前言 为什么会有虚拟机这种东西&#xff1f;它存在的意义是什么[能解决什么问题]&#xff1f;哈哈~你以…

解锁数据分析的神器:ChatGPT引领人工智能革命

&#x1f482; 个人网站:【 海拥】【神级代码资源网站】【办公神器】&#x1f91f; 基于Web端打造的&#xff1a;&#x1f449;轻量化工具创作平台&#x1f485; 想寻找共同学习交流的小伙伴&#xff0c;请点击【全栈技术交流群】 在当今数字化时代&#xff0c;数据分析成为决策…

数据结构(7-2广度~~7-15)所有代码

7-2 迷宫-广度策略 一个陷入迷宫的老鼠如何找到出口的问题。老鼠希望系统性地尝试所有的路径之后走出迷宫。如果它到达一个死胡同&#xff0c;将原路返回到上一个位置&#xff0c;尝试新的路径。在每个位置上老鼠可以向八个方向运动&#xff0c;顺序是从正东开始按照顺时针进行…

【设计模式】结构型设计模式

结构型设计模式 文章目录 结构型设计模式一、概述二、适配器模式&#xff08;Adapter Pattern&#xff09;2.1 类适配器模式2.2 对象适配器模式2.3 接口适配器模式2.4 小结 三、桥接模式&#xff08;Bridge Pattern&#xff09;四、装饰器模式&#xff08;Decorator Pattern&am…

《微信小程序开发从入门到实战》学习二十一

3.3 开发创建投票页面 3.3.9 使用picker选择器组件 使用picker选择器组件增加一个设置截止时间的功能。picker是一个从底部弹出的滚动选择器组件。picker通用属性如下&#xff1a; mode 选择器类型(selector、multiSelector、time、date、region) disabled …

USB转CAN的使用说明

前言 USB转CAN是将 TTL 信号转换为 CAN 信号的模块。采用串口作为嵌入式系统的接口&#xff0c;数据传输简单&#xff0c;无需要学习 CAN 协议&#xff0c;缩短开发周期&#xff0c;降低开发成本。模块兼容 3.3V、5V 电源&#xff0c;搭载一个 32 位的 STM32 处理芯片和一个 C…

buildadmin+tp8表格操作(7.1)表格的事件监听(el-table中的事件)

因为buildAdmin是封装的 el-table的组件&#xff0c;所以el-table中的事件&#xff0c; 也是可以使用的&#xff0c; 两者有几个事件是有共同的&#xff08;比如 双击事件&#xff09;&#xff0c; 这时可以根据自己的需要自行选择 以下代码是 buildadmin 使用 el-table中的事…

键盘映射笔记

dumpkeys命令用于显示当前系统中定义的键盘映射表。它可以帮助用户查看和理解系统中的键盘布局和键盘映射规则。 当用户执行dumpkeys命令时&#xff0c;它会读取系统中的键盘映射表文件&#xff08;通常是/etc/keymaps或/etc/console/boottime.kmap.gz&#xff09;&#xff0c;…

麒麟KYLINOS2303系统上禁用新功能介绍页面

原文链接&#xff1a;麒麟KYLINOS2303系统上禁用新功能介绍页面 hello&#xff0c;大家好啊&#xff0c;今天给大家带来一篇在麒麟KYLINOS2303系统上禁用新功能介绍页面的文章&#xff0c;在我们安装完系统登录后&#xff0c;会发现有新功能介绍这个界面&#xff0c;我们可以通…

buildadmin+tp8表格操作(8) 表格下方添加 合计行

表格的下方可以自定义添加一个合计行&#xff0c;如果有其它的需求&#xff0c; 我们可以添加我们自已需要的行&#xff0c; 并不局限于合计行 以上就可以给表格的最下方添加一个合计行了 完整代码如下 <template><div class"default-main ba-table-box"&…

Blender烘焙AO操作及对应的python代码

&#xff08;一&#xff09;Blender软件操作 1. 导入模型&#xff08;这里省略&#xff09; 2. 材质设置 模型使用的所有材质都需要删除Surface Shader&#xff0c;没有其他多余的计算&#xff0c;可以大量缩短烘焙时间。删除之后的只留下一个材质输出节点&#xff0c;如图所…

Vatee万腾携手Wiki EXPO 2023悉尼峰会 共谱辉煌未来

悉尼&#xff0c;这座充满活力和创新的城市&#xff0c;即将成为全球商业的焦点。2023年11月16日&#xff0c;由WikiEXPO主办的Wiki Finance Expo Sydney 2023在悉尼马丁广场1号富丽敦酒店隆重开幕&#xff0c;这场金融博览会是澳大利亚今年规模最宏大、备受期待的金融科技盛会…