[Javasript] 同时实现单击和双击事件

在同一个元素上同时绑定单击和双击事件:

JavaScript

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
<script type="text/javascript">
    var timer = 0;
    var delay = 200;
    var prevent = false;
    function singleClick(id)
    {
        clearTimeout(timer);
        timer = setTimeout(function() {
        if (!prevent) {copy(id);}
        prevent = false;
        },delay);    //“200”单位是毫秒
    }
 
    function dbClick(id)
    {
        clearTimeout(timer);
        prevent = true;
        edit(id);
    }
 
    function copy(id)
    {
        var textInComment = document.getElementById(id).title;
        var oInput = document.createElement('input');
        oInput.value = textInComment;
        document.body.appendChild(oInput);
        oInput.select(); // 选择对象
        document.execCommand("Copy"); // 执行浏览器复制命令
        oInput.className = 'oInput';
        oInput.style.display='none';
        alert("Copy success, you can paste it!");
    }
 
    function edit(id)
    {
        var textInComment = document.getElementById(id).title;
        var name=prompt("输入的内容","");
        if (name!=null && name!="") {
            alert("你输入的是" + name);
        }
    }
</script>

Html

1
<img src="{% static 'images/comment.png' %}" id="{{forloop.parentloop.counter}}{{forloop.counter}}" onclick="singleClick('{{forloop.parentloop.counter}}{{forloop.counter}}')" ondblclick="dbClick('{{forloop.parentloop.counter}}{{forloop.counter}}')" title='{{v2.comment}}' height="30" width="30" >

  

posted on   张缤分  阅读(266)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示