为了账号安全,请及时绑定邮箱和手机立即绑定

使用 voila 和 Jupyter Hub 渲染 html 时将变量内容复制到剪贴板

使用 voila 和 Jupyter Hub 渲染 html 时将变量内容复制到剪贴板

牛魔王的故事 2023-12-09 15:38:36
我正在使用 Jupyter HUB 从存储在服务器中的 jupyter 笔记本中渲染 Html 页面。使用瞧时,我想创建一个按钮,将特定变量(文本)的内容复制到剪贴板中。重现这种情况的最简单的示例如下。我尝试使用我在此处获得的代码通过 Ipython 注入 JS:(将 JavaScript 变量的输出复制到剪贴板)按钮应该触发代码并将文本放入剪贴板。但事实并非如此。import ipywidgets as widgetsfrom IPython.display import display, HTML, Javascriptmybtn = widgets.Button(description='copy to clipboard',button_style='success')        def mybtn_event_handler(change):    display(Javascript('''var cb = document.getElementById("cb");  cb.value = 'asdfasdfasdfasdfasdfasdf';  cb.style.display='block';  cb.select();  document.execCommand('copy');  cb.style.display='none';''')) mybtn.on_click(mybtn_event_handler)display(mybtn)这在 jupyter hub 中不起作用。我想是因为实际上您没有在本地计算机中运行代码。知道如何处理这种情况吗?实际上,在其他情况下也会遇到这个问题,在这些情况下,使用 Ipython 在本地渲染笔记本时可以与本地浏览器进行交互,瞧。例如,使用 webbrowser 模块打开新选项卡很容易,但当笔记本在 jupyter HUB 中运行时它不起作用。任何想法?注意:代码不会产生错误,日志中只是显示: <IPython.core.display.Javascript object>注意2:实际上在本地运行此代码不起作用,它会产生:添加输出的Javascript错误!类型错误:无法将属性&ldquo;值&rdquo;设置为 null 有关更多详细信息,请参阅您的浏览器 Javascript 控制台。
查看完整描述

1 回答

?
米脂

TA贡献1836条经验 获得超3个赞

根据文档 - 您应该将 onclick 方法输出用widgets.Output(). 因此,为了通过单击按钮来运行一些 Javascript,您应该执行如下操作:


import ipywidgets as widgets

from IPython.display import display, HTML, Javascript


mybtn = widgets.Button(description='copy to clipboard',button_style='success')

output = widgets.Output()


display(mybtn, output)

        

def mybtn_event_handler(b):

    with output:

        display(Javascript('''console.log("Success");''')) 


mybtn.on_click(mybtn_event_handler)


查看完整回答
反对 回复 2023-12-09
  • 1 回答
  • 0 关注
  • 99 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信