vue.js组件和传值以及微信小程序组件和传值
微信小程序组件以及vue.js组件
- 一.微信小程序组件引用
- 1.创建组件Component
- 2.页面组件引用
- 3.组件传值
- 3.1 父视图传值到子组件 (父---->子)
- 3.2 子组件传值给父组件 (子---->父)
- 3.3 父组件方法传递到子组件
- 4. 界面之间的传值
- 4.1 正向传值
- 4.2 反向传值
- 二. uniapp组件的引用
- 1. 组件创建以及引用
- 2. 组件的传值
- 2.1 父组件传值到子组件
- 2.2 子组件传值或者方法到父组件
- 3. 页面传值
- 3.1 页面正向传值
- 3.2 反向传值
- 总结
一.微信小程序组件引用
1.创建组件Component
创建dx.js为子组件
2.页面组件引用
先创建parent父组件页面, 在parent.json中注册组件
"usingComponents": {"component-tag-dx" : "/pages/shengyi/dx/dx",},
在parent.wxml中引用
<component-tag-dx ></component-tag-dx>
3.组件传值
3.1 父视图传值到子组件 (父---->子)
在子组件中dx.js声明要接受的参数
// 这是子组件dx.js
Component({// 组件的属性列表properties: {// 例如滚动视图高度scrollViewH: {type: String,value: '100%'},}
})// 在接受到值以后可以直接在dx.wxml中使用,同样也可以直接通过this.properties.scrollViewH获取到该值
在父组件中进行传值
<!-- 这是父组件parent.wxml -->
<component-tag-dx scrollViewH="90%"></component-tag-dx>
3.2 子组件传值给父组件 (子---->父)
需要再子组件中通过triggerEvent方法进行传值
methods: {//子组件 发生点击事件时触发handleItemTap (e) {// 1 获取点击的索引const { index } = e.currentTarget.dataset;// 2 触发 父组件中的事件,传递数据给父组件 把当前点击的index数据传给父组件this.triggerEvent("tabsItemChange", { index: index });}
在父组件中需要通过bind绑定子组件返回的这个方法,进而拿到传过来的数据
<component-tag-dx bind:tabsItemChange="tabsItemChange" scrollViewH="90%"></component-tag-dx>
// 获取从子组件传回来的数据tabsItemChange (e) {// 获取子组件传过来的数据const name = e.detail },
3.3 父组件方法传递到子组件
例如: 父组件中有3个按钮可以进行切换(按钮1,按钮2, 按钮3)我需要在父组件中点击这3个按钮,把方法传递到子组件中当子组件监听到父组件点击以后,子组件接收方法并且进行页面刷新操作
:
实现:子组件无法监听父组件的方法,父组件也无法把方法传递到子组件中,只能通过传值到子组件然后子组件监听值的改变来判断父组件是否进行了点击
// dx.js子组件Component({
properties:{// 1.首先接收父组件传递过来的值parentIndex: {type: String,value: ''}
},
observers:{// 2. 在监听值是否发生了改变'parentIndex': function (index) {// 如果index == 0说明父组件点击了第一个按钮(按钮1)if (index == 0) {// 在这里执行操作this.setData({triggered: true,})}}
}})
父组件中需要做的操作,在parent.js中,拿到3个按钮点击的索引
// 这个方法是3个按钮点击事件tabClick(e) {let index = e.currentTarget.dataset.indexthis.setData({currentClickIndex: index})},
<!-- 把点击事件的索引传递过去 -->
<component-tag-dx parentIndex="{{currentClickIndex}}"></component-tag-dx>
4. 界面之间的传值
4.1 正向传值
// 正向传值,可以直接从URL中进行拼接,
// 但是如果传递复杂的对象,或者参数较多时,采用这种方式
// 这是页面 Awx.navigateTo({url: '页面B路径',success: function(res) {// 通过eventChannel向被打开页面传送数据res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })}})// 页面B接收
Page({onLoad: function(option){const eventChannel = this.getOpenerEventChannel()// 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据eventChannel.on('acceptDataFromOpenerPage', function(data) {console.log(data)})}
})
4.2 反向传值
// 这是页面 Awx.navigateTo({url: '页面B路径',events: {// 此处用来监听页面B的回调值someEvent: function (data) {let item = that.data.curretItemlet index = that.data.curretItemIndex},}})// 这是页面 B,在onLoad方法中实现就行Page({onLoad: function(option){const eventChannel = this.getOpenerEventChannel()// 把值反向传给界面AeventChannel.emit('someEvent', {data: 'test'});}})// 注意如果是需要点击某个按钮返回,那可以把这个方法放到按钮的点击事件中
二. uniapp组件的引用
1. 组件创建以及引用
直接可以右键创建组件vue,组件可以不注册到page.json界面
// 这里父组件.vue
// 通过路径导入组件
import basics from '../components/CreatBasics';
export default {// 注册组件,注意不要用bas-ics这种格式注册components: {basics: basics},
}
// 在html中直接引用
// <basics></basics>
2. 组件的传值
uniapp组件传值官网: https://uniapp.dcloud.net.cn/tutorial/vue-components.html
2.1 父组件传值到子组件
/****** 这是父组件的html *******/ // ReceivingCommissionOne是引用的子组件
<ReceivingCommissionOne :disposeCode="disposeCode"</ReceivingCommissionOne>/I****** 在子组件中声明要接收的属性 *******/
export default {props: {// 编码disposeCode: {type: String,default: ''},},mounted() {console.log(this.disposeCode)},
}
2.2 子组件传值或者方法到父组件
/******* 这是子组件 ***********/
// 这是某一个按钮的点击事件
backList() {// {} 可以携带任意参数this.$emit('backList', {})
},/******* 这是父组件的html ***********/
<ReceivingCommissionOne @backList="backList" :disposeCode="disposeCode" </ReceivingCommissionOne>
// 实现方法:
backList(data) {}
3. 页面传值
3.1 页面正向传值
/****** 这是页面1 ******/
nextPage() {uni.navigateTo({url: '页面B路径',success: (succ) => {// 在成功的方法中,传值{}succ.eventChannel.emit('changeEdit', {dataDetail: 'text'})}})
}/****** 这是页面2接收 ******/
onLoad(open) {// 接收页面的值const eventChannel = this.getOpenerEventChannel()eventChannel.on('changeEdit', function(data) {}
}
3.2 反向传值
/****** 这是页面1 ******/
nextPage() {uni.navigateTo({url: '页面B路径',events: {// 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据someEvent: function(data) {console.log(data)}},})
}/****** 这是页面2接收 ******/
onLoad(open) {// 传值给界面1const eventChannel = this.getOpenerEventChannel()eventChannel.emit('someEvent', {data: 'data from test page for someEvent'});
}
总结
只是平时工作中记录小程序与uniapp的组件传值
相关文章:
vue.js组件和传值以及微信小程序组件和传值
微信小程序组件以及vue.js组件 一.微信小程序组件引用1.创建组件Component2.页面组件引用3.组件传值3.1 父视图传值到子组件 (父---->子)3.2 子组件传值给父组件 (子---->父)3.3 父组件方法传递到子组件 4. 界面之间的传值4.1 正向传值4.2 反向传值…...
c语言编程题(函数)
1编写函数将一个仅包含整数(可能为负)的字符串转换为对应的整数 方法一使用标准库函数 atoi atoi 函数是C语言标准库中的一个函数,用于将字符串转换为整数。 代码: #include <stdio.h> #include <stdlib.h> // 包含…...
华为eNSP:QinQ
一、什么是QinQ? QinQ是一种网络技术,全称为"Quantum Insertion",也被称为"Q-in-Q"、"Double Tagging"或"VLAN stacking"。它是一种在现有的VLAN(Virtual Local Area Network࿰…...
JAVA基础-多线程线程池
文章目录 1. 多线程1.1什么是多线程(1)并发和并行(2)进程和线程 1.2多线程的实现方式1.2.1 方式一:继承Thread类1.2.2 方式二:实现Runnable接口1.2.3方式三: 实现Callable接口 1.3 常见的成员方法1.3.1 设置…...
HarmonyOS 沉浸式状态实现的多种方式
1. HarmonyOS 沉浸式状态实现的多种方式 HarmonyOS 沉浸式状态实现的多种方式 1.1. 方法一 1.1.1. 实现讲解 (1)首先设置setWindowLayoutFullScreen(true)(设置全屏布局)。 布局将从屏幕最顶部开始到最底部结束,…...
Python3.11.9下载和安装
Python3.11.9下载和安装 1、下载 下载地址:https://www.python.org/downloads/windows/ 选择版本下载,例如:Python 3.11.9 - April 2, 2024 2、安装 双击exe安装 3、配置环境变量 pathD:\Program Files\python3.11.9...
简简单单的UDP
前言 上一篇了解了TCP的三次握手过程,目的、以及如何保证可靠性、序列号与ACK的作用,最后离开的时候四次挥手的内容,这还只是TCP内容中的冰山一角,是不是觉得TCP这个协议非常复杂,这一篇我们来了解下传输层另外一个协…...
减少 try...catch,定义全局统一异常处理器!
前言 软件开发springboot项目过程中,不可避免的需要处理各种异常,spring mvc 架构中各层会出现大量的try {...} catch {...} finally {...}代码块,不仅有大量的冗余代码,而且还影响代码的可读性。这样就需要定义个全局统一异常处理器&#x…...
多点支撑:滚珠导轨的均匀分布优势!
滚珠导轨的滚珠稳定性可以有效保持滚珠导轨的稳定运行,减少滚珠脱落的风险,确保设备的长期稳定性和可靠性。事实上,滚珠导轨的滚珠稳定性主要依赖于以下几个方面: 1、精密的制造工艺:滚珠导轨的导轨和滑块通常采用高精…...
电气火灾探测器在商场火灾隐患监测和火灾预防中的应用
徐悦 安科瑞电气股份有限公司 近年来,全国火灾事故频发,尤其是在大型商场等公共场所,火灾造成了巨大的人员伤亡和财产损失。以南京金盛百货中央门店火灾为例,该起事故暴露了商场在电气安全、消防管理方面的重大隐患,…...
速盾:如何有效防止服务器遭受攻击?
服务器攻击是网络安全中常见的问题,但我们可以采取一系列的措施来有效防止服务器的遭受攻击。以下是一些常见的防御措施: 更新和维护服务器软件:及时更新操作系统、应用程序以及安全补丁,以确保最新版本的软件没有已知的漏洞。同时…...
【今日更新】使用Python辅助处理WebGIS
Linux发行版本: Debian GNU/Linux 12 (bookworm)操作系统内核: Linux-6.1.0-18-amd64-x86_64-with-glibc2.36Python版本: 3.11.2 1.使用Python处理MapServer配置文件Mapfile 创建、分析、修改和格式化的python库 MapServer Mapfiles。 Python 2和3 兼容 纯Python-无MapServer依…...
Linux 消息队列
在Linux中,线程间消息队列可以通过使用System V消息队列或POSIX消息队列来实现。 使用System V消息队列: System V消息队列是一种基于IPC(Inter-process Communication,进程间通信)的通信机制,可以用于进程…...
十大经典排序算法-冒泡算法详解介绍
1、十大经典排序算法 排序算法是《数据结构与算法》中最基本的算法之一。 排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要…...
delphi 编译多语言工程 error RC2104 : undefined keyword or key name:
Delphi 10.3中建立多语言工程,编译时出现错误:error RC2104 : undefined keyword or key name: 出现错误的的文件是.rc文件,出现错误的位置是 System_JSONConsts_SInvalidJavascriptQuote, L"Invalid JavaScript string quote character…...
[python] 如何debug python脚本中C++后端的core dump
文章目录 Debug过程Reference Debug过程 另外:对于core dump: gdb版本是>7,gdb从版本7开始支持对Python的debug。确保你的系统中安装了 GDB 调试器和对应版本的 Python 调试信息包(例如 python-dbg 或 python-debuginfo)。 #…...
Ecmascript(ES)标准
Ecmascript(ES)标准 ECMAScript(通常简称为 ES)是一种标准化的脚本语言,由 Ecma International 通过 ECMA-262 标准定义。ECMAScript 是 JavaScript 的规范版本,几乎所有的现代浏览器和许多服务器端环境&a…...
易泊车牌识别相机:4S 店的智能之选
在当今数字化时代,科技的进步不断为各个行业带来更高效、便捷的解决方案。对于 4S 店来说,易泊车牌识别相机的出现,无疑为其运营管理带来了全新的变革。 一、易泊车牌识别相机的强大功能 易泊车牌识别相机以其卓越的性能和精准的识别能力&…...
Webpack 深度解析与实战指南
文章目录 前言一、安装于基本配置安装Webpack 和 Webpack CLI创建基本配置文件 二、加载器常见的加载器配置加载器 三、插件(Plugins)常用的插件配置插件 四、性能优化缓存代码分割Tree Shaking压缩 五、开发服务器安装服务器配置服务器启动服务器生产环…...
【RabbitMQ】06-消费者的可靠性
1. 消费者确认机制 没有ack,mq就会一直保留消息。 spring:rabbitmq:listener:simple:acknowledge-mode: auto # 自动ack2. 失败重试机制 当消费者出现异常后,消息会不断requeue(重入队)到队列,再重新发送给消费者。…...
地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
Java 语言特性(面试系列1)
一、面向对象编程 1. 封装(Encapsulation) 定义:将数据(属性)和操作数据的方法绑定在一起,通过访问控制符(private、protected、public)隐藏内部实现细节。示例: public …...
【Oracle APEX开发小技巧12】
有如下需求: 有一个问题反馈页面,要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据,方便管理员及时处理反馈。 我的方法:直接将逻辑写在SQL中,这样可以直接在页面展示 完整代码: SELECTSF.FE…...
条件运算符
C中的三目运算符(也称条件运算符,英文:ternary operator)是一种简洁的条件选择语句,语法如下: 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true,则整个表达式的结果为“表达式1”…...
【决胜公务员考试】求职OMG——见面课测验1
2025最新版!!!6.8截至答题,大家注意呀! 博主码字不易点个关注吧,祝期末顺利~~ 1.单选题(2分) 下列说法错误的是:( B ) A.选调生属于公务员系统 B.公务员属于事业编 C.选调生有基层锻炼的要求 D…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
初探Service服务发现机制
1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能:服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源…...
免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...
MFC 抛体运动模拟:常见问题解决与界面美化
在 MFC 中开发抛体运动模拟程序时,我们常遇到 轨迹残留、无效刷新、视觉单调、物理逻辑瑕疵 等问题。本文将针对这些痛点,详细解析原因并提供解决方案,同时兼顾界面美化,让模拟效果更专业、更高效。 问题一:历史轨迹与小球残影残留 现象 小球运动后,历史位置的 “残影”…...
