> 백엔드 개발 > PHP 튜토리얼 > javascript - 如何在html页面中修改所有外部链接形式?

javascript - 如何在html页面中修改所有外部链接形式?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-06 20:41:24
원래의
1014명이 탐색했습니다.

例如,我有:http://A.com/a/index.html,该页面里有很多不同网站的外链(如b.com、c.com、d.com等)。
现在我想,用php、JS或其他方法实现,点击外链接“b.com”,新窗口打开的地址是“http://a.com/b/index.php?b.com”的效果。
谢谢,因不太懂代码,希望大大们赐教,如何统一替换所有的外链形式?

回复内容:

例如,我有:http://A.com/a/index.html,该页面里有很多不同网站的外链(如b.com、c.com、d.com等)。
现在我想,用php、JS或其他方法实现,点击外链接“b.com”,新窗口打开的地址是“http://a.com/b/index.php?b.com”的效果。
谢谢,因不太懂代码,希望大大们赐教,如何统一替换所有的外链形式?

捕捉 click 事件,然后在事件处理函数里修改 href

<code>$(document).on('click', 'a:not([data-bypass])', function(e) {
    var $target = $(e.target),
        href = $target.attr('href'),
        prefix = 'http://a.com/b/index.php?';

    if (/^http:\/\//.test(href)) {
        $target.attr('href', prefix + href);
    }

    // 把检查过的 <a> 标记一下,以后就不会再次做检查
    $target.attr('data-bypass', 'bypass');
});
</a></code>
로그인 후 복사

这种思路跟直接遍历 <a></a> 修改 href 的思路比较,好处是绝无死角且效率高,对于后面再加入的 <a></a> 也依然有效。而且对于需要特殊处理的 <a></a>,只需要在标签里面先写上 data-bypass 属性就行,很方便。

jquery 获取全部 A 标签,然后批量替换 href 的值为 http:// 开头的

<code>$("a[href*='http://']").each(function() {
  $(this).attr('href','http://www.fsdeveloper.net'+'/'+$(this).attr('href'));
});
</code>
로그인 후 복사

类似这种写法,

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿