Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >小程序父子组件传参_微信小程序修改全局变量

小程序父子组件传参_微信小程序修改全局变量

作者头像
全栈程序员站长
发布于 2022-10-03 09:33:40
发布于 2022-10-03 09:33:40
1.2K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

点击原创或者分类虽然样式如首页一样变化,但是其父组件的最终isActive的值并未发生改变,但是样式发生改变是因为拿取的是Component>里面的properties中的tabs,你点击下去的时候一样拿取tabs数组,所以不会报错。因此子组件必须通过方法进行修改父组件中的isActive的值,方法如下:


components/Tabs/Tabs.js

点击事件触发父组件中自定义事件 同时传递数据给 父组件

this.triggerEvent(“父组件自定义事件的名称”,要传递的参数)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// components/Tabs/Tabs.js
Component({
  properties: {
    tabs:{
      type:Array, // 接收数据类型
      value:[]    // 数据默认值
    }

  },
 
  data: {

  },

  methods: {
    handleItemTap(e) {
      const { index } = e.currentTarget.dataset;
      this.triggerEvent("itemChange",{index});
      let { tabs } = this.data;
      tabs.forEach(
        (v, i) => i === index ? v.isActive =
          true : v.isActive = false
      );
      this.setData({
        tabs
      })
    }
  }
})

子向父传递数据 通过事件的方式传递

  • 在子组件的标签上加入一个 自定义事件 bind+自定义事件名称=“回调函数handleItemChange”
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// pages/demo-component/demo-component.wxml
<Tabs tabs="{
  
  {tabs}}" binditemChange="handleItemChange"></Tabs>

工作原理:子组件Tabs.js执行this.triggerEvent(“itemChange”,{index});这个代码时—–》相当于触发到pages/demo-component/demo-component.wxml页面的自定义标签<Tabs></Tabs>的binditemChange事件,相当于执行了“回调函数handleItemChange”方法


子组件components/Tabs/Tabs.js

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// components/Tabs/Tabs.js
Component({
  properties: {
   
    tabs:{
      type:Array,
      value:[]
    }

  },

  data: {

  },

  methods: {
    handleItemTap(e) {
      const { index } = e.currentTarget.dataset;
      this.triggerEvent("itemChange",{index});
   
    }
  }
})

父组件pages/demo-component/demo-component.js

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// pages/demo-component/demo-component.js
Page({

  data: {
    tabs: [
      {
        id: 0,
        name: "首页",
        isActive: true
      },
      {
        id: 1,
        name: "原创",
        isActive: false
      },
      {
        id: 2,
        name: "分类",
        isActive: false
      },
      {
        id: 3,
        name: "关于",
        isActive: false
      }
    ]
  },
  // 自定事件 用来接收子组件传递的数据
  handleItemChange(e) {
    // console.log(e);  位置:e.detail
    const { index } = e.detail; // 拿到索引值
    let { tabs } = this.data;   // 拿到原数组
    tabs.forEach(
      (v, i) => i === index ? v.isActive =
        true : v.isActive = false
    );                          // 修改原数组
    this.setData({
      tabs
    })                          // 值填充回去
  }
})

页面呈现结构pages/demo-component/demo-component.wxml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// pages/demo-component/demo-component.wxml
<Tabs tabs="{
  
  {tabs}}" binditemChange="handleItemChange"></Tabs>

渲染结果

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/197136.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月5日 上,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【愚公系列】《微信小程序与云开发从入门到实践》031-开发一款多Tab页自定义组件
在现代移动应用中,良好的用户体验离不开清晰的界面布局和流畅的交互设计。微信小程序作为一种轻量级的应用形式,广泛应用于各类场景,而多Tab页设计则越来越成为用户界面的重要组成部分。通过合理的Tab页面设计,用户可以更方便地在不同功能模块之间切换,从而提升使用的便捷性和舒适感。
愚公搬代码
2025/01/21
1250
【愚公系列】2022年10月 微信小程序-优购电商项目-自定义组件
组件(Component)是对数据和方法的简单封装。组件可以有自己的属性和方法。属性是组件数据的简单访问者。方法则是组件的一些简单而可见的功能。使用组件可以实现拖放式编程、快速的属性处理以及真正的面向对象的设计。
愚公搬代码
2022/11/12
2740
【愚公系列】2022年10月 微信小程序-优购电商项目-自定义组件
微信小程序【常用组件及自定义组件】
微信小程序入门的文章,其实暂时就更新到这里了,还有一个生命周期的内容,感觉当初整理的不是很好就不更新了,学完了 WXML、WXSS、一些常用组件,还有事件绑定,其实一个较为不错的页面已经能自己搭建出来了,如果你还想继续往后面研究,我给一下方向就是,可以开始看 与后台交互的内容了,发送异步请求,对数据进行回显等,回显内容时,你就又可以开始考虑用什么别的组件,可以让页面的数据加载或者观看更加顺滑,美观,当然有很多小伙伴都是后端,所以,可以自己搭个后台,试着弄用户登录授权这块,这块算是小程序一个重要的点,要好好研究一下,以后要做的事情,就和传统的后端基本一样了。我的文章都是根据官网写的原生写法,当然你也可以看一下一些小程序框架,或者看一看 ES6 的内容,毕竟我也是个后端,也没细细研究前端的内容,有什么想法或者意见,可以在公众号菜单页面直接给后台发文字,或者发送邮件:ideal_bwh@163.com
BWH_Steven
2020/09/18
1.9K0
☀️苏州程序大白一文教你学会微信小程序开发☀️《❤️记得收藏❤️》
3、与data同级 并且可以将input中输入的值与data中定义的属性绑定,使用this.setData({属性:e.detail.value})。
苏州程序大白
2021/09/29
9440
微信小程序组件化编程和实践(上)
从小程序基础库版本 1.6.3 开始,小程序支持简洁的组件化编程。查看自己使用的小程序基础库版本,可以通过在开发者工具右侧点击详情查看:
疯狂的小程序
2018/01/25
2K0
高效开发必备!小程序组件复用的实用技巧
嘿,各位开发小伙伴们👨‍💻👩‍💻!在开发支付宝小程序的奇妙世界里,你是不是经常被重复劳动搞得焦头烂额呢🧐?今天,小编就来给大家支支招,分享超实用的支付宝小程序组件复用技巧,让你的开发效率蹭蹭往上涨📈,告别那些让人头疼的重复工作~
小白的大数据之旅
2025/04/24
780
高效开发必备!小程序组件复用的实用技巧
【愚公系列】2022年10月 微信小程序-优购电商项目-⾃定义组件传参
文章目录 前言 一、id和data-xxx传参 二、导航传值 三、父子组件传值 ---- 前言 组件传参是小程序中非常重要的一个功能,因为小程序大多都是组件形式存在的。 一、id和data-xxx传参 view class="container"> <view class="usermotto"> <!-- 传入普通字符串数值 --> <button class="user-motto" bindtap="onGetIdValue" id="winne" data-name="nam
愚公搬代码
2022/11/12
7630
微信小程序零基础入门--->自定义组件
类似于页面,一个自定义组件由json、wxml、wxss、js四个文件组成
用户5899361
2020/12/07
1.1K0
微信小程序零基础入门--->自定义组件
微信小程序 父子组件传值通信
微信小程序父组件往子组件传值: 父:<getCode phone="{ {phone}}" bind:myevent="onGetCode"></getCode> 通过phone=”{ {phone}}”传向子组件 子:
全栈程序员站长
2022/08/29
1.2K0
微信小程序自定义组件
微信小程序自定义组件 一. 创建自定义组件 类似于页面,一个自定义组件由 json wxml wxss js 4个文件组成 二.组件声明 首先需要在自定义组件所在的 json 文件中进行自定义组件声明 { "component": true } 三.编辑组件 同时,还要在 wxml 文件中编写组件模板,在 wxss 文件中加入组件样式 wxml与xcss和普通页面设置差不多 wxml <!-- 这是自定义组件的内部WXML结构 --> <view class="inner"> {{innerText
小小咸鱼YwY
2020/06/19
8110
微信小程序自定义组件
其中,components为组件目录,nodemodules为模块目录,pages为小程序的页面目录,utils为一些基础功能的封装。好比安装的第三方百度统计功能在此。
mySoul
2018/09/15
2.8K0
小程序 | 11-组件化
自定义组件由 json、wxml、wxss、js 四个文件组成,我们通常是在根目录下创建一个文件夹——components,在该文件夹中存放我们自定义的公共组件。
CnPeng
2021/05/17
2.5K0
小程序 | 11-组件化
微信小程序 页面与自定义组件数据通信
说明:页面通过my-property讲example字符串传递给自定义组件,同样也可以使用数据绑定的方法
天天_哥
2018/11/11
3.3K0
微信小程序 页面与自定义组件数据通信
小程序-实现自定义组件以及自定义组件间的通信
对于组件的封装,在小程序当中对于多个页面的复用有着重要的作用,小程序中注册的每个页面都是独立的
itclanCoder
2020/11/09
2.8K0
小程序-实现自定义组件以及自定义组件间的通信
vue和微信小程序的区别
vue的钩子函数在跳转新页面时,钩子函数都会触发,但是小程序的钩子函数,页面不同的跳转方式,触发的钩子并不一样。
IT工作者
2022/02/22
1.4K0
【愚公系列】2022年11月 微信小程序-优购电商项目-意见反馈页面
对于需要收集产品上线后用户实际使用感受的,意见反馈绝对是一个很好用的功能,开发设计成本很低,却能获得比较显著的效果,但就因为是小功能,所以往往不被重视。如果一个产品是有长远发展规划的,个人觉得应该在产品的第一个版本上线的时候就应该配备意见反馈的功能,这里所能收集到的有需求,有 BUG,还有其他的,只要有问题,就能找到解决的办法,没有任何反馈的时候,就只能靠产品的规划和设计师的水平了,当然也不是一味的遵循用户的意见,但绝对是一个非常好的参考来源。
愚公搬代码
2022/11/16
4610
【愚公系列】2022年11月 微信小程序-优购电商项目-意见反馈页面
【愚公系列】2022年02月 微信小程序-Component组件的通信与事件
事件系统是组件间通信的主要方式之一。自定义组件可以触发任意的事件,引用组件的页面可以监听这些事件。
愚公搬代码
2022/02/28
8460
微信小程序组件调用和传值
微信小程序像Vue和React一样赋于了组件的开发能力,支持组件的调用和传值,同时由于小程序上传时限制在2MB以内,对于稍微大一点的小程序组件的使用就特别重要了,下面给大家介绍下小程序的组件用法。
越陌度阡
2020/11/26
1.6K0
微信小程序开发全流程:从注册到上线的完整指南
这种说法不能说不真实,只能说肯定不是这么简单的事情。毕竟广告收入的多少,归根结底还是取决于用户量,不可能随便做个小程序,就能吸引大量用户来看广告。
苏琢玉
2025/03/13
6420
微信小程序开发全流程:从注册到上线的完整指南
【小程序】组件通信
父组件还可以通过 this.selectComponent() 获取子组件实例对象 这样就可以直接访问子组件的任意
陶然同学
2023/02/24
1.9K0
【小程序】组件通信
推荐阅读
相关推荐
【愚公系列】《微信小程序与云开发从入门到实践》031-开发一款多Tab页自定义组件
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验