V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hteen
V2EX  ›  前端开发

如何实现点击按钮弹出“粘贴”按钮

  •  
  •   hteen ·
    hteen · 2022-10-08 11:49:42 +08:00 · 1215 次点击
    这是一个创建于 795 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如图

    x8zpzq.jpg

    第 1 条附言  ·  2022-10-08 14:23:23 +08:00

    需要先 navigator.permissions.query 申请权限, 并且测试发现只有在 127.0.0.1 和 https 下才有用

    
        <div class="query"></div>
    
        <textarea id="output" type="text"></textarea>
        <button id="paste">粘贴</button>
    
        <script>
            navigator.permissions.query({
                name: 'clipboard-read'
            }).then(permissionStatus => {
                // permissionStatus.state 的值是 'granted'、'denied'、'prompt'
                document.querySelector(".query").innerText = permissionStatus.state
            });
    
            function paste() {
                navigator.clipboard.readText().then(
                    clipText => document.querySelector("#output").value = clipText);;
            }
    
            document.querySelector("#paste").addEventListener("click", paste);
        </script>
    
    8 条回复    2022-10-08 15:43:54 +08:00
    bojackhorseman
        1
    bojackhorseman  
       2022-10-08 13:02:24 +08:00 via iPhone
    element ui 有个 tooltip 组件
    ifdef
        2
    ifdef  
       2022-10-08 13:05:10 +08:00
    用自定义组件就可以
    moult
        3
    moult  
       2022-10-08 13:24:12 +08:00
    我觉得你想问的是,怎么弹出系统自带的这个弹出框吧。
    但是我感觉这个弹出层是前端自己实现的,不是系统自带的。
    hteen
        4
    hteen  
    OP
       2022-10-08 13:45:07 +08:00
    @moult
    @bojackhorseman
    @ifdef 并不是指这个 UI, 是实现 “粘贴” 这个功能
    fe619742721
        5
    fe619742721  
       2022-10-08 13:50:12 +08:00
    是 [复制] 还是 [粘贴] ?
    粘贴到页面中显示还是复制到剪贴板?
    renmu
        6
    renmu  
       2022-10-08 13:52:03 +08:00 via Android
    你就调用黏贴 api 或者用 clipboard api
    vone
        7
    vone  
       2022-10-08 14:08:31 +08:00
    killmojo
        8
    killmojo  
       2022-10-08 15:43:54 +08:00
    浏览器权限现在,很多需要申请权限的操作都限制 https 。localhost 是为了方便测试
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5521 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 02:43 · PVG 10:43 · LAX 18:43 · JFK 21:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.