JS小应用:复制指定div的内容到剪贴板

要复制指定div的内容到剪贴板,可以使用以下JavaScript代码:

function copyDivContentToClipboard(divId) {
    // 获取div元素
    var div = document.getElementById(divId);
    if (!div) {
        return;
    }
    // 创建一个新的临时div来持有要复制的内容
    var tempDiv = document.createElement("div");
    tempDiv.style.position = "absolute";
    tempDiv.style.left = "-10000px";
    tempDiv.appendChild(div.cloneNode(true));
    document.body.appendChild(tempDiv);

    // 选中内容
    var selection = window.getSelection();
    var range = document.createRange();
    range.selectNodeContents(tempDiv);
    selection.removeAllRanges();
    selection.addRange(range);

    // 复制到剪贴板
    var successful = false;
    try {
        successful = document.execCommand('copy');
    } catch (err) {
        console.log('Oops, unable to copy');
    }

    // 移除临时div
    document.body.removeChild(tempDiv);

    if (successful) {
        console.log('内容已复制到剪贴板');
    }
}

使用这个函数,只需传入你想要复制内容的div的ID即可。例如,如果你的div的ID是"myDiv",你可以这样调用函数:

copyDivContentToClipboard("myDiv");

比如:

<button class="base" onclick="copyDivContentToClipboard('myDiv');">复制</button>

---------------

本篇文章仅是小技巧,为那些新入行的朋友们做参考。不喜勿喷谢谢 ~

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
要在Streamlit中运行JavaScript并将内容复制剪贴板,你可以使用streamlit-components库中的Clipboard组件。 首先,你需要安装streamlit-components库: ``` pip install streamlit-component-lib ``` 然后,创建一个名为`clipboard.js`的JavaScript文件,其中包含以下代码: ``` import {useState, useEffect} from "react"; import {Button} from "antd"; function Clipboard(props) { const [copySuccess, setCopySuccess] = useState(""); function copyText(){ navigator.clipboard.writeText(props.copyText); setCopySuccess("已复制剪贴板!"); }; useEffect(() => { let timeout; if (copySuccess !== "") { timeout = setTimeout(() => { setCopySuccess(""); }, 3000); } return () => { clearTimeout(timeout); }; }, [copySuccess]); return ( <div> <Button onClick={copyText}>{props.buttonText}</Button> {copySuccess} </div> ); } ``` 这个代码包含一个名为`Clipboard`的React组件。它将使用`navigator.clipboard.writeText`函数将文本复制剪贴板,并显示一个成功消息。 接下来,创建一个名为`clipboard.py`的Python文件,其中包含以下代码: ``` import streamlit.components.v1 as components Clipboard = components.declare_component( "Clipboard", url="http://localhost:3001", ) def clipboard(copyText: str, buttonText: str): return Clipboard(copyText=copyText, buttonText=buttonText, key=1) ``` 这个代码使用`components.declare_component`函数声明名为`Clipboard`的组件,并将其URL设置为`http://localhost:3001`(这是组件的默认URL)。 最后,在Streamlit应用程序中,你可以使用以下代码来使用`clipboard`函数: ``` import clipboard text_to_copy = "Hello, world!" button_text = "复制剪贴板" if clipboard.clipboard(text_to_copy, button_text): st.success("已复制剪贴板!") ``` 这个代码将使用`clipboard`函数来创建一个复制文本到剪贴板的按钮,并在成功时显示一个消息。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鱼仰泳

码字不易,诚待支持,吾道不孤!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值