【问题标题】:Change `href`s links via `onmousedown`,`click` events通过 `onmousedown`、`click` 事件更改 `href` 的链接
【发布时间】:2017-03-26 15:10:55
【问题描述】:

基本上,当我在 Yandex 中执行 a search 时,我会得到如下信息:

但是,当我右键单击并复制链接时,我没有获得真正的链接,而是获得了垃圾链接(在重定向到我想要的链接之前,它具有跟踪我的点击功能的中间功能)。

我正在尝试编写一个脚本来删除那些垃圾链接。这是我尝试过的:

function decodeURL(str) {
   return decodeURIComponent((str+'').replace(/\+/g, '%20'));
}

function getRealLinks() {
    var classes = document.getElementsByClassName('organic typo typo_text_m typo_line_s'); // gets any search result

    var cleanLinks = new Array(); // we'll store any clean link to this array

    for (i = 0; i < classes.length; i++) {
        var html = classes[i].innerHTML; // we get part of the inner html of the selected search result
        var pattern = /(url=(.*?))(?=&amp;\w+=)/; // with this regex we'll match the url
        var match = pattern.exec(html); // attempt matching pattern
        cleanLinks.push(decodeURL(match[2])); // decode the url, then push the match to the array
    }

    console.log(cleanLinks);
}

function bindEventListeners() {
    var lis = document.getElementsByTagName('li'); // search results have `li` selector

    for (var i = 0; i < lis.length; i++) { // iterate every element
      (function(i) {
        lis[i].addEventListener('click', function() { // add a listener to the current element
          alert(this.dataset.cid); // each result has an id (by default between 0-9)
        }, false);
      })(i);
    }
}

bindEventListeners();

getRealLinks() 为我提供了正确的链接,但我现在不知道如何“进行”以将搜索结果的 hrefs 替换为干净的链接。

bindEventListeners() 被称为绑定侦听器,当在搜索结果正文部分实现点击时将触发该侦听器。获得点击的搜索结果的id 对我很有用,只是为了让链接偏离我需要的链接。比如用户点击索引为3的搜索结果,我就做var search_3 = getRealLinks()[3]

如何将您可以看到的那些链接替换为 JavaScript 中的干净链接?

【问题讨论】:

  • 我也尝试了this code 的部分内容,但它甚至不起作用。
  • 仅供参考:Google search link fix:适用于 Google 和 Yandex。适用于 Chrome 和 Firefox。

标签: javascript jquery google-chrome-extension yandex


【解决方案1】:

在最顶层的 DOM 对象 window 上附加一个 mousedown 侦听器,并为 addEventListeneruseCapture 参数指定 true 以在捕获开始时拦截事件从window 到点击目标的阶段。也就是说,我们的代码将在目标的onmousedown 之前运行。

// ==UserScript==
// @name     Defluff yandex links
// @include  *://yandex.*/*
// ==/UserScript==

window.addEventListener('mousedown', event => {
    const a = event.target.closest('a');
    if (a) {
        a.onmousedown = null;
    }
}, true);

【讨论】:

  • 我一直在寻找这样的东西。这也适用于 Google。
猜你喜欢
  • 1970-01-01
  • 2012-12-17
  • 1970-01-01
  • 2017-04-02
  • 1970-01-01
  • 2011-01-06
  • 2014-03-24
  • 2011-01-13
  • 2013-10-11
相关资源
最近更新 更多