iou3344 2023-03-05 19:51 采纳率: 84.1%
浏览 33
已结题

双击才打开链接失效了,网址传递不过去

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>

<span class="checkbox2">
  <span class="upout"><a href="https://www.aaa.com">AAA</a></span>
  <span class="upout"><a href="https://www.bbb.com">BBB</a></span>
  <span class="upout"><a href="https://www.ccc.com">CCC</a></span>
  <span class="upout"><a href="https://www.ddd.com">DDD</a></span>
</span>
<br><br><br>
<input type="text" name="name" style="width:100%" placeholder="搜索 " autocomplete="off">

<script type="text/javascript">
//单击取链接的文字,双击才打开链接
$(document).ready(function(){
    $('.upout').click(function(event){
        var inputVal = $('input[name="name"]').val();
        var name = $(this).text();
        if (inputVal.indexOf(name) == -1) {
            if (inputVal == '') {
                $('input[name="name"]').val(name);
            } else {
                $('input[name="name"]').val(inputVal + ' ' + name);
            }
        }
        event.preventDefault();
        if (event.detail === 2) {
            var url = $(this).attr("href");
            window.open(url, '_blank');
        }
    });
});
</script>

这段jquery代码有问题了~
单击取链接的文字成功了
双击才打开链接失效了:双击可以打开新窗口,但是新窗口的地址栏是about:blank,网址并没有传递过去吗?还是什么原因呢?

  • 写回答

2条回答 默认 最新

  • iou3344 2023-03-05 21:28
    关注
    <script type="text/javascript">
        //单击取链接的文字,双击才打开链接
        $(document).ready(function(){
            var clicked = false;
            $('.upout').click(function(event){
                var inputVal = $('input[name="name"]').val();
                var name = $(this).text();
                if (inputVal.indexOf(name) == -1) {
                    if (inputVal == '') {
                        $('input[name="name"]').val(name);
                    } else {
                        $('input[name="name"]').val(inputVal + ' ' + name);
                    }
                }
                if (!clicked) {
                    clicked = true;
                    setTimeout(function() {
                        if (clicked) {
                            clicked = false;
                        } else {
                            var url = $(event.target).closest('a').attr('href');
                            window.open(url, '_blank');
                        }
                    }, 300);
                } else {
                    clicked = false;
                    var url = $(event.target).closest('a').attr('href');
                    window.open(url, '_blank');
                }
                event.preventDefault();
            });
        });
    </script>
    

    这样写可以了,感觉写复杂了,但还是拿出来给需要的朋友。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月21日
  • 已采纳回答 3月13日
  • 创建了问题 3月5日

悬赏问题

  • ¥15 如何在音频中嵌入字符串(水印)信息进行传递
  • ¥30 plc怎么以设计说明书申请软著
  • ¥15 硬盘识别不了,需要初始化,可我的数据怎么办
  • ¥15 lvm2被mask了,怎么unmask都没用(标签-ubuntu|关键词-apt)
  • ¥15 交叉注意力机制的残差问题
  • ¥15 微信小程序:渲染收货地址时页面不显示
  • ¥20 win7 64位DirectShow提示初始化失败如何解决?
  • ¥20 小规模孤立词识别系统设计
  • ¥15 关于Java对接海康威视车牌识别一体机SDK是否需要固定外网的IP?
  • ¥15 Linux扩容时,格式化卡住了:vgdispaly查看卷组信息,没有输出