当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > 背投广告设计:用最少的时间来做最效率的事情

CSS样式表
IE6编码问题无法正确解析CSS文件
网页设计中的黄金比例
网站设计Tab标签切换的效果制作
DIV滚动条随机位置的设置技巧
重置默认样式:css reset
css美化input file按钮的方法
支持Web标准,在中国
网页制作css不解析问题
网页制作:不同浏览器的CSS Hack写法
word-wrap和word-break解决连续字符自动换行
CSS样式表最佳习惯
网页制作学习之CSS样式表的优先权
CSS属性display:inline-block
网页开头部分的声明DOCTYPE
CSS布局:居左之后居右是100%宽度显示问题
CSS设计多列多模块等高网页布局
真正的利用DIV+CSS优化站点
网页作品:CSS主题网站欣赏
CSS+XHTML制作的简单网页下拉菜单
加深对HTML和CSS标签语义化的理解

CSS样式表 中的 背投广告设计:用最少的时间来做最效率的事情


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 139 ::
收藏到网摘: n/a


  对于背投广告的原理来说并没有什么难度,无非打开的窗口失去焦点(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 参数内容。