鸟食轩
Microsoft .NET[C#] MVP 2003
随笔 - 332, 文章 - 870, 评论 - 5722, 引用 - 356
在popup窗口中俘获事件的缺陷&修复
我们在处理HTML元素的事件时,通常可以使用两种方法来添加其处理函数。一是直接向HTML元素的
事件处理回调
(如:onclick、onlond等)赋值;一是使用元素的attachEvent()方法来添加处理函数。这两种方法对于普通的页面表现出来的效果是完全相同的,而对于popup它们却有很大的差别。
先看下面的popup中事件处理示例,再来说是什么问题:
<
script
language
="javascript"
>
function
NormalEventListener(elmt)
{
alert(event);
}
function
AttachEventListener(evt)
{
alert(evt);
}
var
popwin
=
window.createPopup();
var
popdoc
=
popwin.document;
var
div
=
popdoc.createElement('DIV');
div.style.width
=
'
100
%
';
div.style.height
=
'
100
%
';
div.style.border
=
'dotted 1px blue';
div.innerText
=
'click me.';
div.onclick
=
function
Click()
{
NormalEventListener(
this
);
}
;
div.attachEvent('onclick', AttachEventListener);
popwin.document.body.appendChild(div);
popwin.show(
100
,
100
,
200
,
200
);
</
script
>
这个示例中,分别使用了两种方法来添加事件处理函数。对于attachEvent这种方式,我在'
使用Popup窗口创建无限级Web页菜单(3)
'一文中介绍过它的用法,而且说明了怎么在其处理函数中获取全局事件变量
event
。就是被attach的处理函数的第一个参数即是默认的
event
变量。
今天我无意中使用了另一种方法,向
事件处理回调
赋值的方法附加事件处理函数,div.onclick =
function
()。却发现了一个popup窗口中响应时间处理函数的缺陷。执行上面的代码,我们会发现NormalEventListener()方法的elmt参数是引发事件的元素本身的引用,而此时调用
event
属性,却发现
event
这厮居然是:null
。这可咋怎呐?!
原来NoramlEventListener()中的
event
是window.
event
,因为这个函数定义在IE的window的作用域内,它的引用也可以写成window.NormalEventListener(),而我们触发的事件是在popup窗口中的window中。就是说IE的window和popwin.document.parentWindow是两个不同的域,当然这个时候window.
event
就是null了。解决这个问题的办法有两个,一可以去取popwin.document.parentWindow的
event
,不过这个方法比较麻烦,需要专门去记录那个popwin变量。另外还有一个最简单的方法可以取到正确的
event
属性。因为每个事件触发的源元素(srcElement)和触发它的事件属性总是在同一个域中,所以我们就可以使用如下办法将其取到:
function
NormalEventListener(elmt)
{
var
evt
=
elmt
.document.parentWindow.event;
alert(evt);
}
这个elmt参数是从Click函数中传递过来的触发事件的元素本身,即:
event
.srcElement。
绿色通道:
好文要顶
关注我
收藏该文
与我联系
posted on 2005-03-05 01:14
birdshome
阅读(6719)
评论(4)
编辑
收藏
评论
169599
#1楼
回复
引用
前段时间在写pop时也碰到这个问题后就全改成attachEvent了,当时就觉得elmt.document.parentWindow.event这样引用过于麻烦
2005-05-11 21:20
|
edison1024
#2楼
回复
引用
如果把函数定义和调用的onClick都写在一个popup窗口的body中,点击触发时找不到方法的定义,不知道是怎么回事.
2005-06-07 14:17
|
wearebug
#3楼
[
楼主
]
回复
引用
查看
@wearebug
你怎么把脚本写到popup窗口里去的?我试了没有问题呀。
<
html
>
<
body
>
<
script
>
function
fnRun(elmt)
{
var
popup
=
window.createPopup();
var
doc
=
popup.document;
doc.write(
this
.document.documentElement.outerHTML);
doc.close();
popup.show(
100
,
100
,
300
,
300
, elmt);
}
</
script
>
<
button
onclick
="fnRun(this)"
>
Click
</
button
>
</
body
>
</
html
>
2005-06-07 15:29
|
birdshome
#4楼
回复
引用
谢谢,我搞错了.我使用xmlhttp把另一个xml装载进来,然后给当前页的XXX.innerHTML赋值的,但是当前页面没有定义要调用的方法,是在那个xml文件中定义的.这个还是由于不同的域引起的问题.
2005-06-07 17:16
|
wearebug
注册用户登录后才能发表评论,请
登录
或
注册
,
返回博客园首页
。
首页
博问
闪存
新闻
园子
招聘
知识库
最新IT新闻
:
·
伊朗封杀Gmail和Facebook等互联网服务
·
分析称专利之争让谷歌苹果两败俱伤
·
Android平台发现新型手机病毒Rootsmart
·
HTC首款Android4.0手机大曝光
·
这是不是你期待的 iPad 3?
»
更多新闻...
最新知识库文章
:
·
高级编程语言的发展历程
·
如何学习一门新的编程语言?
·
学习不同编程语言的重要性
·
为什么我喜欢富于表达性的编程语言
·
计算机专业的女生为什么要学编程
»
更多知识库文章...
China-pub 2011秋季教材巡展
China-Pub 计算机绝版图书按需印刷服务
导航
博客园
首页
新随笔
联系
订阅
管理
公告
Invert
原创
技术文章和心得,
转载
必须注明来源
"博客园"
!
贴子以"现状"提供,且没有任何担保,同时也没有授予任何权利。
昵称:
birdshome
园龄:
7年10个月
荣誉:
推荐博客
粉丝:
73
关注:
3
搜索
常用链接
我的随笔
我的评论
我的参与
最新评论
我的标签
我的标签
Nokia 6300
(2)
fan
(1)
qq
(1)
腾讯
(1)
输入法
(1)
隐私
(1)
随笔分类
(337)
.NET的私有工具类(2)
(rss)
.NET技术开发相关(34)
(rss)
Asp.net控件开发(14)
(rss)
Debug中的滑铁卢(9)
(rss)
Enjoy Computer :)(27)
(rss)
Jscript&Dhtml开发(162)
(rss)
技术区里的非技术(49)
(rss)
开发中遇到的虫子(14)
(rss)
其它编程相关内容(16)
(rss)
商务智能(BI)开发(10)
(rss)
文章分类
(147)
北京的幸福生活(29)
(rss)
不得不转载(19)
(rss)
乖乖的文章(6)
(rss)
那时还没有blog(4)
(rss)
那是相当八卦(10)
(rss)
手机短信息(1)
(rss)
我们的文章(40)
(rss)
珍贵照片的背景(4)
(rss)
重庆的幸福生活(34)
(rss)
相册
2005 Kick Off @ 涞滩
2006 Kick Off @ 钓鱼城
2006 Offsite @ 四面山
2006 Wedding @ 昆明
2007 Marriage @ 哈尔滨
2007 Offsite @ Thailand
2007 Offsite @ 海南云天
2007 Training @ Seattle
2007 Travelling @ 云南
2008 Travelling @ 天津
乱七八糟的收集
Ex-Colleagues
Jason Lei's Space
.Net Life
(rss)
Jasper
(rss)
Michelles Space
xingd.net
(rss)
玻璃缸
(rss)
短鲷生活
海阔天空
录一室
(rss)
完美的泡菜
(rss)
怡红公子
(rss)
竹叶尖的BLOG
常用链接
Engadget 中文版
PDFCHM eBooks
SitePoint Forums
The Code Project
安利上海直销店
哈尔滨工业大学
哈工大紫丁香
海归论坛
(rss)
沙坪坝区中医院
兄弟情深
没有可乐的日子
葡萄树下不乘凉
(rss)
斯普特尼克
猪头小队长
(rss)
积分与排名
积分 - 3145044
排名 - 6
最新评论
阅读排行榜
推荐排行榜