给VML增加事件

www.BCZJ.com【编程之家】 www.bczj.com admin 2007-2-22 14:02:52

VML 和 HTML 的紧密结合,使的给 VML 增加事件变得很容易.所有的 HTML 里面的事件都可以应用到 VML 中间来!下面的例子是演示:当鼠标移动到圆的时候,圆就跟着鼠标移动了,当鼠标点击后,圆停止移动。

<v:oval id="circle" style="position:relative;width:100;height:80;" onmouseover="move()" fillcolor=red />

<script>

var canmove=false;

function move()

{

circle.style.position="absolute";

canmove=true;

document.onmousemove=new Function("if(canmove){circle.style.posLeft=event.x;circle.style.posTop=event.y;}");

}

document.onclick=new Function("canmove=false");

</script>

不知道你有没有注意,VML的事件区域是严格按照本身的形状的,并不是像图片那样,都是矩形。顺便介绍一下 Function 对象,使用Function 对象,如果函数的内容比较少,而且调用就一次,就可以使用 Function 对象了,使用方法就是用 new 创建一个 Function 对象,参数就是 函数的内容。控制事件的比较好的办法是使用一个全局变量,一个事件的执行依赖一个全局变量,而另一个事件可以设置这个全局变量,这样一来,就可以让事件来控制事件了。

责任编辑: 参与评论
【编程之家】版权所有 www.bczj.com 沪ICP备06025676号 QQ:382611662
Powered By: 上海驰志网络 3.0 Beta