如何在页面调用utility bar并传递参数至lwc组件

2024-09-09 17:20

本文主要是介绍如何在页面调用utility bar并传递参数至lwc组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.在app的utility item中添加lwc组件:

2.调用utility bar api的方式有两种:

方法一,通过lwc调用:

import {LightningElement,api ,wire   } from 'lwc';
import { publish, MessageContext } from 'lightning/messageService';
import CallCenterMessageChannel from '@salesforce/messageChannel/callCenterChannelName__c';
import{open , getAllUtilityInfo} from 'lightning/platformUtilityBarApi';
import { CloseActionScreenEvent } from 'lightning/actions';export default class CallCenterMessageService extends LightningElement {@api selectedIds; // 从 Flow 传递的记录 ID@api recordId@wire(MessageContext)messageContext;// 当组件加载时处理记录 IDasync connectedCallback() {// console.log('Selected Record IDs: ', this.selectedIds);console.log('record Id: ', this.recordId);debuggerawait this.handleOpen();setTimeout(() => {this.handlePublish();this.closeQuickAction()}, 1000); // 延迟1000毫秒,可以根据情况调整时间}//调用utility api打开utility barasync handleOpen(){debuggerconst unitilyInfo=await getAllUtilityInfo();for (let i = 0; i < unitilyInfo.length; i++) {console.log('util at index', i, ':', unitilyInfo[i]);if(unitilyInfo[i].utilityLabel==='呼叫控制台'){open(unitilyInfo[i].id);}}}//publish事件至channelhandlePublish(){// debugger// console.log('handlePublish--Selected Record IDs: ', JSON.stringify(this.selectedIds));const payload = { recordId:  this.recordId};publish(this.messageContext, CallCenterMessageChannel, payload);}closeQuickAction() {this.dispatchEvent(new CloseActionScreenEvent());}}

方式二,通过aura调用:

handleGetUtilityInfo: function (component, event, helper) {debuggervar utilityBarAPI = component.find("utilitybar");console.log('utilityBarAPI--->' + JSON.stringify(utilityBarAPI));console.log('utilityBarAPI--->' + JSON.stringify(utilityBarAPI.getAllUtilityInfo()));utilityBarAPI.getAllUtilityInfo().then(function (response) {console.log(response.length);console.log(JSON.stringify(response));for (let i = 0; i < response.length; i++) {var myUtilityInfo = response[i];console.log("myUtilityInfo--》" + JSON.stringify(myUtilityInfo));if (myUtilityInfo.utilityLabel === '呼叫控制台') {utilityBarAPI.openUtility({utilityId: myUtilityInfo.id});}}})setTimeout(() => {// this.handlePublish();}, 1000); // 延迟1000毫秒,可以根据情况调整时间},handlePublish: function (cmp, event, helper) {var payload = {recordId: cmp.get("v.recordId")};cmp.find("callCenterMessageChannel").publish(payload);}

3.传递参数,通过message channel publish事件,在utility bar中lwc/aura组件订阅事件接受参数:

  handleCallCenterChannel: function (cmp, message, helper) {// debugger;console.log("订阅信息!!");if (message != null && message.getParam("recordId") != null) {console.log("recordId--->" + message.getParam("recordId"));cmp.set("v.recordId", message.getParam("recordId"));}},

tips:publish事件之前,需要提前open utility bar,否则utility bar中组件无法订阅

这篇关于如何在页面调用utility bar并传递参数至lwc组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

python如何调用java的jar包

《python如何调用java的jar包》这篇文章主要为大家详细介绍了python如何调用java的jar包,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录一、安装包二、使用步骤三、代码演示四、自己写一个jar包五、打包步骤六、方法补充一、安装包pip3 install

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1