0

0

使用 Gradio 中的自定义 JavaScript 事件处理程序

霞舞

霞舞

发布时间:2025-09-10 11:03:17

|

1039人浏览过

|

来源于php中文网

原创

使用 gradio 中的自定义 javascript 事件处理程序

本文介绍了如何在 Gradio 应用中使用自定义 JavaScript 事件处理程序与 Python 代码进行交互。通过在 Gradio 应用中嵌入 JavaScript 代码,监听特定事件,并将事件数据传递回 Python 函数,实现更灵活的前后端交互。本文提供了一个具体示例,展示了如何监听图像点击事件,并将点击坐标传递给 Python 函数进行处理。

在 Gradio 应用中,有时我们需要利用 JavaScript 监听特定事件,并将事件数据传递回 Python 代码进行处理。虽然 Gradio 提供了自定义 JavaScript 的功能,但直接将 JavaScript 事件数据传递到 Python 函数并非易事。本文将介绍一种利用隐藏的文本框作为桥梁,实现 JavaScript 和 Python 之间数据传递的方法。

解决方案

该方案的核心思想是:

  1. JavaScript 事件监听: 在 JavaScript 中监听目标事件(例如,按钮点击、图像点击等)。
  2. 修改隐藏文本框的值: 当事件触发时,JavaScript 代码将事件数据写入一个隐藏的文本框。
  3. Gradio change 事件: 利用 Gradio 文本框的 change 事件,当文本框的值发生变化时,触发一个 Python 函数。
  4. Python 函数处理数据: Python 函数接收文本框的值,并进行相应的处理。

示例代码

以下代码演示了如何监听图像点击事件,并将点击坐标传递给 Python 函数。

极限网络办公Office Automation
极限网络办公Office Automation

专为中小型企业定制的网络办公软件,富有竞争力的十大特性: 1、独创 web服务器、数据库和应用程序全部自动傻瓜安装,建立企业信息中枢 只需3分钟。 2、客户机无需安装专用软件,使用浏览器即可实现全球办公。 3、集成Internet邮件管理组件,提供web方式的远程邮件服务。 4、集成语音会议组件,节省长途话费开支。 5、集成手机短信组件,重要信息可直接发送到员工手机。 6、集成网络硬

下载

立即学习Java免费学习笔记(深入)”;

import gradio as gr

script = """
function setupClick() {
    console.log("BEFORE");
    const video = document.getElementById("video_feed");
    const textbox = document.getElementById("output_box");


    if (!video) {
        console.log("Required elements not found.");
        return;
    }

    const boundingBox = video.getBoundingClientRect();

    const outputBox = document.querySelector("#real_box textarea")

    video.addEventListener("click", function handleClick(event) {
        console.log("Got click: ", event);
        const relativeX = event.clientX - boundingBox.left;
        const relativeY = event.clientY - boundingBox.top;

        const message = `Clicked at X: ${Math.round(relativeX)} Y: ${Math.round(relativeY)}`;
        console.log(message);

        outputBox.value = message;
        let event2 = new Event("input")
        outputBox.dispatchEvent(event2);




    }, false);

    console.log("AFTER");

    return 'Animation created';
}
"""


def handle_click(x=0, y=0):
    return f"Received from JS: X={x}, Y={y}"


def handle_textbox_change(text):
    return "Received from JS: " + text


with gr.Blocks(js=script) as demo:
    gr.Markdown("Click on the image to trigger a Python function")
    output = gr.Textbox(label="Response from Python", elem_id="real_box")

    textbox = gr.Textbox(elem_id="output_box")
    textbox.change(fn=handle_textbox_change, inputs=textbox, outputs=output)

    # Add a visible image to click on
    img = gr.Image(value="test_images/frog.jpg", elem_id="video_feed")

demo.launch()

代码解释:

  • script 变量: 包含 JavaScript 代码的字符串。
    • setupClick 函数:在页面加载后执行,用于设置点击事件监听器。
    • 获取 video_feed 元素(图像)和 output_box 元素(隐藏文本框)。
    • 为 video_feed 元素添加点击事件监听器。
    • 在点击事件处理函数中,计算相对于图像的点击坐标。
    • 将坐标信息写入 output_box 文本框。
    • 手动触发 input 事件,以便 change 事件可以被监听到。
  • handle_textbox_change 函数: Python 函数,当 textbox 的值发生变化时被调用。
    • 接收 textbox 的值(包含点击坐标信息)。
    • 返回一个包含接收到的信息的字符串。
  • gr.Blocks: 定义 Gradio 界面。
    • js=script:将 JavaScript 代码嵌入到 Gradio 应用中。
    • gr.Textbox(elem_id="output_box"):创建一个隐藏的文本框,用于接收 JavaScript 传递的数据。elem_id 用于在 JavaScript 代码中查找该元素。
    • textbox.change(fn=handle_textbox_change, inputs=textbox, outputs=output):当 textbox 的值发生变化时,调用 handle_textbox_change 函数,并将 textbox 的值作为输入传递给该函数。函数的输出将显示在 output 文本框中。
    • gr.Image(elem_id="video_feed"):创建一个图像,用于监听点击事件。elem_id 用于在 JavaScript 代码中查找该元素。

注意事项

  • 数据安全: 这种方法不适用于传递敏感信息,因为文本框的值是可以在客户端查看的。
  • 错误处理: JavaScript 代码中应包含错误处理逻辑,以防止因元素未找到等原因导致程序崩溃。
  • 复杂数据: 如果需要传递复杂的数据结构,可以将数据序列化为 JSON 字符串,然后在 Python 代码中进行反序列化。
  • 替代方案: 对于更复杂的需求,可以考虑创建自定义 Gradio 组件,这样可以更直接地控制 JavaScript 和 Python 之间的交互。

总结

本文介绍了一种利用隐藏文本框和 Gradio change 事件,实现 JavaScript 和 Python 之间数据传递的方法。虽然这种方法有一些限制,但它可以快速解决一些简单的前后端交互问题。在实际应用中,应根据具体需求选择合适的解决方案。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

707

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

625

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

735

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

616

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1234

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

573

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

695

2023.08.11

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 1.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号