首页 > 开发 > CSS > 正文

背投广告设计:用最少的时间来做最效率的事情

2024-07-11 08:21:02
字体:
来源:转载
供稿:网友

  对于背投广告的原理来说并没有什么难度,无非打开的窗口失去焦点(blur),而原来页面得到焦点(focus)。但对于流行的浏览器来说,如果非用户行为的弹出窗口(即 onload 时,直接window.open ),会被浏览器默认拦截。

  背投广告,既然被称为广告,那如何才能让广告主的钱花得实在,花得乐意呢?

  我们可以增加判断,如果该弹出窗口被浏览器拦截,则只要用户点击页面就触发 window.open 事件,这样一般不会拦截,浏览器会认为这是用户的默认行为。

  代码可编写如下:

var $e = yahoo.util.event;
var adpopup;
var popad = function(surl,sname,sfeatures,breplace) {
    if (adpopup) return;
    if(sname == undefined) {
        sname = '_blank';
    };
    if(sfeatures == undefined) {
        sfeatures = '';
    };
    if(breplace == undefined) {
        breplace = false;
    };
    adpopup = window.open(surl,starget,sfeatures,breplace);
    adpopup.blur();
    adpopup.opener.focus();
    $e.removelistener(document.body, 'click', arguments.callee);
}
try {
    popad();
} catch (e) {
    $e.on(document.body, 'click', popad);
}

  当然如果用户浏览器安装了拦截插件,那很有可能不会弹出(比如 firefox 的 noscript 插件,就不允许任何弹出窗)。方法不是绝对的,也不是最好的,只是用最少的时间来做最效率的事情。

  ps:可以通过模拟 form 提交的方式来弹出窗口,穿越性(相对于一般拦截弹窗的插件)很好,不过无法设置 sfeatures 参数内容。

点击这里返回 css教程 频道

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表