微信小程序开发系列(十五)·bind 绑定的事件(冒泡事件)、catch 绑定的事件(非冒泡事件)

目录

1.  事件分类

1.1  bind 绑定的事件(冒泡事件)

1.2  catch 绑定的事件(非冒泡事件)

1.3  代码


1.  事件分类

事件分为 冒泡事件 和 非冒泡事件:

冒泡事件:当一个组件的事件被触发后,该事件会向父节点传递,若此时父节点也有绑定事件,则会一并触发。

非冒泡事件:当一个组件的事件被触发后,该事件不会向父节点传递,若此时父节点也有绑定事件,则不会触发父节点的事件。

使用 bind 绑定的事件,会触发事件冒泡,如果想阻止事件冒泡,可以使用 catch 来绑定事件。

1.1  bind 绑定的事件(冒泡事件

        使用bind来监听用户的触摸事件、表单提交事件等。当事件发生时,绑定的事件处理函数会被调用。

        找到index.wxml文件,创建一个“line”的类,写入代码:

<view class="line"></view>

        找到app.scss文件,对该类进行相关属性的配置:

.line{
  border-top: 10rpx solid lightseagreen;
  margin: 100rpx 0;
}

        找到index.wxml文件,创建一个“catch”的类,并创建一个按钮,写入代码:

<view class="catch">
  <button>按钮</button>
</view>

         找到index.scss文件,将其定义一个 Flex 容器.catch,将其高度设为300rpx,背景颜色为天蓝色,并且内部的子元素在垂直方向上居中对齐:

.catch{
  // 将 .catch 元素设置为 Flex 布局,使其内部的子元素可以通过弹性布局进行排列。
  display: flex;
  // 设置 .catch 元素的高度为 300rpx
  height: 300rpx;
  // 设置 .catch 元素的背景颜色为天蓝色
  background-color: skyblue;
  // 在 Flex 容器中,设置了交叉轴上的对齐方式为居中,这样内部的元素在交叉轴上(垂直方向)将会居中对齐
  align-items: center;
}

  1. display: flex;: 将 .catch 元素设置为 Flex 布局,使其内部的子元素可以通过弹性布局进行排列。
  2. height: 300rpx;: 设置 .catch 元素的高度为 300rpx,rpx 是一种相对长度单位,常用于小程序开发。
  3. background-color: skyblue;: 设置 .catch 元素的背景颜色为天蓝色。
  4. align-items: center;: 在 Flex 容器中,设置了交叉轴上的对齐方式为居中,这样内部的元素在交叉轴上(垂直方向)将会居中对齐。

        找到index.wxml文件,分别对父进程和子进程使用“bind”绑定事件,其中父进程绑定“parentHandler”,子进程绑定“btnHandler”代码如下:

<view class="catch" bind:tap="parentHandler">
  <button bind:tap="btnHandler">按钮</button>
</view>

        找到index.js文件,分别对父子节点进行编写触发事件后的显示:

  parentHandler(){
    console.log('父组件绑定的事件')
  },

  btnHandler(){
    console.log('子组件触发的事件')
  },

        点击“按钮”可以看到,不仅子节点触发,父节点也触发:

        在微信小程序中,可以通过 bind 来绑定事件处理函数,常见的用法是在组件上使用 bind 来监听用户的触摸事件、表单提交事件等。当事件发生时,绑定的事件处理函数会被调用。

        例如,可以通过以下方式在一个按钮上绑定一个 tap(点击)事件处理函数:

<button bindtap="handleTap">点击我</button>

        在上面的例子中,bindtap 表示绑定了一个 tap 事件处理函数 handleTap。当用户点击按钮时,handleTap 函数会被调用。

        另外,还有一些其他常见的事件绑定方式,如 catch 。catch 用于阻止事件向父节点传递,即非冒泡事件的绑定。例如:

<button catchtap="handleTap">点击我</button>

        在这种情况下,点击按钮时只会触发当前按钮上的 handleTap 事件处理函数,不会向父节点传递该事件。

1.2  catch 绑定的事件(非冒泡事件

         找到index.wxml文件,将子进程的bind绑定事件改为catch绑定事件:

<view class="catch" bind:tap="parentHandler">
  <button catch:tap="btnHandler">按钮</button>
</view>

        此时点击“按钮”,会发现只有子节点触发了,父节点没有进行触发:

1.3  代码

app.scss:

input{
  border: 1px solid #ccc;
}

.line{
  border-top: 10rpx solid lightseagreen;
  margin: 100rpx 0;
}

index.wxml:


<!-- 第一种绑定事件的方式 bind:事件名-->
<button type="primary" bind:tap="handler">绑定事件</button>

<!-- 第二种绑定事件的方式 bind事件名-->
<!-- <button type="primary" type="warn" bindtap="handler">绑定事件</button> -->

<!-- 在小程序中,input输入框默认没有边框,需要自己添加样式 -->
<input type="text" bindinput="getInputVal" />

<view class="line"></view>

<view class="catch" bind:tap="parentHandler">
  <button catch:tap="btnHandler">按钮</button>
</view>

index.js:

// index.js
Page({

  parentHandler(){
    console.log('父组件绑定的事件')
  },

  btnHandler(){
    console.log('子组件触发的事件')
  },

  // 事件处理函数需要写到page()方法中
  handler(event){
    // console.log('事件触发了~~~')
    console.log(event)
  },

  getInputVal(event){
    console.log(event.detail.value)
  }
  // hand(){
  //   console.log('第二种事件触发了~~~')
  // }


})

总结:

  1. 冒泡事件:

    • 在小程序中,一些事件(如 touch 事件)是支持冒泡的,即当子组件的事件被触发后,该事件会向父节点传递。
    • 如果父节点也有绑定相同类型的事件处理函数,则会依次触发这些处理函数。
    • 通过冒泡事件,可以实现事件委托和更灵活的事件处理逻辑。
  2. 非冒泡事件:

    • 另外一些事件(如 input 事件、form 类事件)是不支持冒泡的,即当子组件的事件被触发后,该事件不会向父节点传递。
    • 即使父节点有相同类型的事件处理函数,也不会触发父节点上的事件处理函数。

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

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

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

相关文章

浅谈字典攻击

一、前言 字典攻击是一种常见的密码破解方法&#xff0c;它使用预先编制的字典文件作为攻击字典&#xff0c;通过尝试猜测密码的方式来破解密码。下面是一个关于字典攻击的博客&#xff0c;希望能够为您了解字典攻击提供帮助。 二、字典攻击概述 字典攻击是一种密码破解方法&…

微信小程序 弹窗禁止底部页面滚动

解决方法&#xff1a; 在弹窗上给添加catchtouchmove catchtouchmovereturn

个人商城系统开源(展示宣传)

原文地址&#xff1a;个人商城系统开源&#xff08;展示宣传&#xff09; - Pleasure的博客 下面是正文内容&#xff1a; 前言 由于近期实在没有什么话题可写和一些有趣的项目教程可以分享。所以我只能决定将我自己亲手编写的一个迷你商城系统进行开源。 也就是放在我博客右边…

VR虚拟生态探索介绍|元宇宙文旅|VR设备价格

虚拟现实&#xff08;VR&#xff09;虚拟生态探索是一种通过VR技术让用户体验并探索虚拟环境的活动。在这样的环境中&#xff0c;用户可以通过头戴式显示器和其他感知设备沉浸在一个虚拟的世界中&#xff0c;仿佛身临其境。 在VR虚拟生态探索中&#xff0c;用户可以探索各种不同…

数据库备份.....

一.环境准备 数据库备份&#xff0c;数据库为school&#xff0c;素材如下 >create database school; >use school1.创建student和score表CREATE TABLE student ( id INT(10) NOT NULL UNIQUE PRIMARY KEY , name VARCHAR(20) NOT NULL , sex VARCHAR(4) , bi…

【PCL】(二十五)基于Min-Cut的点云分割

Min-Cut Based Segmentation 提出这个方法的论文&#xff1a;Min-Cut Based Segmentation of Point Clouds 最大流最小割问题 min_cut_segmentation.cpp #include <iostream> #include <vector> #include <pcl/io/pcd_io.h> #include <pcl/point_types…

基于ZEM系列台式扫描电镜和EDS能谱仪的岩石元素成分分析研究

上一期里我们对几种不同种类的岩石在特定作用下的破坏特征进行了表征&#xff0c;感兴趣的同学可以阅读《从宏观到微观——泽攸科技ZEM系列台式扫描电镜在岩石分析中的应用》。岩石是地球表层和地壳的基本组成物质&#xff0c;其成因和成岩过程复杂多样&#xff0c;岩石的元素组…

PythonStudio 控件使用常用方式(十)TLabel和TLinkLabel

PythonStudio是一个极强的开发Python的IDE工具&#xff0c;它使用的是Delphi的控件&#xff0c;常用的内容是与Delphi一致的。但是相关文档并一定完整。现在我试试能否逐步把它的控件常用用法写一点点&#xff0c;也作为PythonStudio的参考。 Tlabel是最常用的控件&#xff0c…

【论文阅读】Segment Anything论文梳理

Abstract 我们介绍了Segment Anything&#xff08;SA&#xff09;项目&#xff1a;新的图像分割任务、模型和数据集。高效的数据循环采集&#xff0c;使我们建立了迄今为止最大的分割数据集&#xff0c;在1100万张图像中&#xff0c;共超过10亿个掩码。 该模型被设计和训练为可…

【最详细的python教程】Python基本数据类型及运算符

&#x1f383;Python基本数据类型 &#x1f38b;整数** 整数是表述整数的数值&#xff0c;没有小数部分。在Python中&#xff0c;整数包括正整数、负整数和0&#xff0c;在Python中数值超过计算机自身的计算功能时会自动转用高精度计算。整数类型包括二进制、八进制、十进制和…

摘花生c++

题目 Hello Kitty想摘点花生送给她喜欢的米老鼠。 她来到一片有网格状道路的矩形花生地(如下图)&#xff0c;从西北角进去&#xff0c;东南角出来。 地里每个道路的交叉点上都有种着一株花生苗&#xff0c;上面有若干颗花生&#xff0c;经过一株花生苗就能摘走该它上面所有的…

指针易错点(超详细)

&#x1f4cc; 博客主页 爆打维c 本文将介绍指针基本知识点及易错点&#xff0c;刚入门学习c语言的小伙伴们可以收藏起来&#xff0c;方便找到。 目录 一、指针是什么&#xff1f; 1.const修饰指针 总结: 2.野指针 野指针成因: 3.指针数组与数组指针的区别 3.1指针数…

数据分析师必备:五款数据可视化工具对比与推荐

在数字化时代&#xff0c;数据可视化产品成为了企业和个人进行数据分析、信息呈现的重要工具。市面上涌现了众多数据可视化产品&#xff0c;它们各具特色&#xff0c;功能各异。本文为大家简要介绍五款市面上热门的数据可视化产品。 一、Tableau Tableau是一款功能强大的数据…

精读《React Conf 2019 - Day2》

1 引言 这是继 精读《React Conf 2019 - Day1》 之后的第二篇&#xff0c;补充了 React Conf 2019 第二天的内容。 2 概述 & 精读 第二天的内容更为精彩&#xff0c;笔者会重点介绍比较干货的部分。 Fast refresh Fast refresh 是更好的 react-hot-loader 替代方案&am…

mysql日常优化的总结

文章目录 一、数据表结构相关优化建字段类型注意事项1. int类型的选择2.varchar、char、text类型3.date、datetime、timestamp类型 表规划1. 垂直分表2. 水平分表 二、查询语句优化1.对于字段多的表&#xff0c;避免使用SELECT *2.避免使用!操作符3.避免使用null做条件4.like查…

echarts中toolbox 中文乱码问题

问题描述 本地引用的echarts源文件&#xff0c;页面其他部分编码显示正常&#xff0c;唯独toolbox鼠标悬停在上面时提示信息显示乱码。 如图所示&#xff1a; 尝试过的方法 使用sublime text 3&#xff0c;notepad&#xff0c;记事本更改文件编码为utf-8引入时&#xff0c;在sc…

爱普生宣布开发出独特的宽幅度LVDS输出 —可灵活选择与LSI

爱普生宣布开发出独特的宽幅度LVDS输出 —可灵活选择与LSI -相匹配的低噪声输出 精工爱普生公司(TSE: 6724&#xff0c;“爱普生”)开发了一种新的晶体振荡器差分输出方案。新方案&#xff0c;宽幅低压差分信号(WA-LVDS)&#xff0c;可以灵活选择最适合LSI所需的幅值水平的输出…

双体系Java学习之浮点型,字符型,布尔型三种数据类型

浮点型 //小数&#xff1b;浮点数float num5 50.1F;//float类型要在数字后面加个Fdouble num6 3.1415926;字符型 char c1 a;char c2 中;System.out.println(c1);System.out.println((int) c1);//强制换行System.out.println(c2);System.out.println((int) c2);//强制换行//…

React报错 之 Objects are not valid as a React child

原文链接&#xff1a; 1、React报错之Objects are not valid as a React child 2、Objects are not valid as a React child error [Solved] 作者&#xff1a;Borislav Hadzhiev 以下文中涉及到的链接均来自于该作者&#xff0c;他写了很多相关的文章&#xff0c;可以多看看他的…

【大模型】Hugging Face下载大模型的相关文件说明

Hugging Face下载大模型文件说明 1.前言 ​ 上图是毛毛张在HuggingFace的官网上的ChatGLM-6B大模型的所有文件,对于初学者来说,对于上面的文件是干什么的很多小伙伴是很迷糊的,根本不知道是干什么的,毛毛张接下来将简单讲述一下上面的每个文件的作用。 2.文件说明 在Hug…