Gradio中button组件的基本使用

Gradio中button组件的基本使用

Gradio中的button组件是用于在页面中放置按钮的组件,是最常用的组件之一。其常用于一些点击事件的实现,具体需要通过其组件的click事件实现,但是在使用时又与写传统前端代码时的click实现不太一样。简单来说,前端代码中点击按钮要实现的东西(包含其他组件值的变化)基本都写在点击触发的函数中,但是gradio中button组件的click事件中的函数只做值的处理,改变其他组件的值或属性(呈现结果)是通过函数的输出来控制

gradio.Button.click(fn, inputs, outputs)
  • 使用click事件时最常用的就是这三个参数,fn是点击时触发的函数,只要填函数本身;inputs是函数的输入参数,需要注意的是实际填的并不是int、str这样的基本类型,而是gradio组件本身,比如gradio.Textbox,但并不是说会将gradio组件直接传给fn,而是将组件的值(value属性)传给fn,所以fn接的还是基本类型;outputs是函数的输出参数,和inputs一样,也是gradio组件,如果最终的目的是想改变outputs中组件的值的话,fn回传基本类型即可,如果是需要改变组件的其他属性(例如visible、interactive),那就需要回传gr.update()来实现

示例代码

import gradio as gr

def update(name):
    return f"Welcome to Gradio, {name}!", gr.update(interactive=False), gr.update(visible=True)
def clear():
    return "", "", gr.update(interactive=True), gr.update(visible=False)

with gr.Blocks() as demo:
    gr.Markdown("Start typing below and then click **Run** to see the output.")
    with gr.Row():
        inp = gr.Textbox(placeholder="What is your name?")
        out = gr.Textbox()
    btn = gr.Button("Run")
    btn_c = gr.Button("clear", visible=False)
    btn.click(fn=update, inputs=inp, outputs=[out,btn,btn_c])
    btn_c.click(fn=clear, outputs=[inp,out,btn,btn_c])

demo.launch()

以上代码就可以实现点击Run按钮时将左侧文本框的输入拼接上"Welcome to Gradio",并显示在右侧文本框中,同时将Run按钮置灰,显示出clear按钮,在clear按钮点击后将左右文本框清空并让Run按钮回复、clear按钮消失。

示例

参考资料

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值