0

我已经编写了这个脚本的大部分内容,但我知道我缺少一个关键点。

我需要调用函数(见下文)...

function InternalLink() {
Page_ShowPopOnExit = false;
}

...在 if/else 语句中以某种方式(参见下面的代码)来检测被点击的是内部链接而不是页面关闭/外部链接。

    function LinkConvert() {
var href;
                var anchors = document.getElementsByTagName('a');

                for(var y=0; y<anchors.length; y++)
                {
                                href = anchors[y].href.toLowerCase();
                                if (!(href.indexOf("http://")!=-1 && href.indexOf(MySiteDomain)==-1))
                                                {
                                                anchors[y].clickhandler=InternalLink()
                                                XBrowserAddHandlerPops(anchors[y],"click","clickhandler");
                                                }
                }
}

最新的)总代码如下,Ty 帮助我完成我的代码(或修复它:)

function exitwindow() {
var Page_ShowPopOnExit=true;
var MySiteDomain='www.example.com';
var url = '/exit.html';
var win = 'toolbar=0,directories=0,menubar=0,scrollbars=0,resizable=0,width=250,height=300';
if (Page_ShowPopOnExit==true){
   open(url,'WindowName',win);
   } else (Page_ShowPopOnExit==false)
   {alert('Internal Link')}
}

function InternalLink() {
  Page_ShowPopOnExit = false;
}

function LinkConvert() {
var href;
                var anchors = document.getElementsByTagName('a');

                for(var y=0; y<anchors.length; y++)
                {
                                href = anchors[y].href.toLowerCase();
                                if (!(href.indexOf("http://")!=-1 && href.indexOf(MySiteDomain)==-1))
                                                {
                                                anchors[y].clickhandler=InternalLink()
                                                XBrowserAddHandlerPops(anchors[y],"click","clickhandler");
                                                }
                }
}
function XBrowserAddHandlerPops(target,eventName,handlerName) {
  if ( target.addEventListener ) {
    target.addEventListener(eventName, function(e){target[handlerName](e);}, false);
  } else if ( target.attachEvent ) {
    target.attachEvent("on" + eventName, function(e){target[handlerName](e);});
  } else {
    var originalHandler = target["on" + eventName];
    if ( originalHandler ) {
      target["on" + eventName] = function(e){originalHandler(e);target[handlerName](e);};
    } else {
      target["on" + eventName] = target[handlerName];
    }
  }
}
4

1 回答 1

0

从您的代码中猜测您想要在访问者单击链接到不同域的链接时弹出一个窗口。

如果链接 URL 看起来像内部链接(没有“http://”或域存在),您的代码当前通过将 onclick 处理程序附加到所有链接来执行此操作。然后它将一个布尔值设置Page_ShowPopOnExit为 false ,这应该防止弹出挂钩在被调用时生成弹出窗口(exitwindow- 在您的示例代码中没有被调用)

我认为有一个更简单的方法。即只需附加一个 onclick 处理程序,该处理程序将为每个不是内部链接的链接弹出一个窗口:

function createPopup() {
    var url = '/exitexample.html';
    var win ='toolbar=0,directories=0,menubar=0,scrollbars=0,resizable=0,width=250,height=300';
    open(url,'WindowName',win);
}

var anchors = document.getElementsByTagName('a');
for(var y=0; y<anchors.length; y++) {
    href = anchors[y].href.toLowerCase();
    if (href.indexOf("http://") !== -1 && href.indexOf(MySiteDomain) !==-1) {
        anchors[y].onclick = createPopup; // you might want to replace this with attachEventListener etc.
    }
}
于 2011-08-23T19:53:08.137 回答