javascript实现淡蓝色的鼠标拖动选择框实例
网络编程 2021-07-04 21:48www.168986.cn编程入门
这篇文章主要介绍了javascript实现淡蓝色的鼠标拖动选择框,可实现鼠标拖动出现淡蓝色选择框的效果,涉及javascript鼠标事件及样式的操作技巧,需要的朋友可以参考下
本文实例讲述了javascript实现淡蓝色的鼠标拖动选择框。分享给大家供大家参考。具体实现方法如下
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://.w3./TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://.w3./1999/xhtml"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <style type="text/css"> #rectBox { background:#CCFFFF; border:2px solid #0099FF; filter:alpha(opacity=30); opacity:0.3; position:absolute; } </style> <head> <title>一个鼠标选择框</title> <script type="text/javascript"> function Rect() { this.doc = document.documentElement; if(!this.doc) return; this.startX = ''; this.startY = ''; this.rect = null; rectSelf = this; } Rect.prototype.down = function(e) { var e = e?e:window.event; rectSelf.startX = e.clientX?e.clientX + document.body.scrollLeft:e.pageX; rectSelf.startY = e.clientY?e.clientY + document.body.scrollTop:e.pageY; rectSelf.showRect(true); } Rect.prototype.up = function(e) { rectSelf.rectBox.style.width = '0px'; rectSelf.rectBox.style.height = '0px'; rectSelf.showRect(false); } Rect.prototype.move = function(e) { if(rectSelf.rectBox) { var currentX = e.clientX?e.clientX + rectSelf.doc.scrollLeft:e.pageX; var currentY = e.clientY?e.clientY + rectSelf.doc.scrollTop:e.pageY; rectSelf.rectBox.style.width = Math.abs(currentX - rectSelf.startX) + 'px'; rectSelf.rectBox.style.height = Math.abs(currentY - rectSelf.startY) + 'px'; if(currentX - rectSelf.startX < 0) { rectSelf.rectBox.style.left = currentX + 'px'; } if(currentY - rectSelf.startY < 0) { rectSelf.rectBox.style. = currentY + 'px'; } //document.title = "left:"+currentX + 'px '+":"+currentY + 'px '; } } Rect.prototype.showRect = function(bool) { if(bool) { if(!this.rectBox) { this.rectBox = document.createElement("div"); this.rectBox.id = "rectBox"; document.body.appendChild(this.rectBox); } this.rectBox.style.display = "block"; this.rectBox.style.left = this.startX + 'px'; this.rectBox.style. = this.startY + 'px'; this.addEventListener(this.doc , 'mousemove' , this.move); } else { if(this.rectBox) { this.rectBox.style.display = "none"; } this.removeEventListener(this.doc , 'mousemove' , this.move); } } Rect.prototype.addEventListener = function(o,e,l) { if (o.addEventListener) { o.addEventListener(e,l,false); } else if (o.attachEvent) { o.attachEvent('on'+e,function() { l(window.event); }); } } Rect.prototype.removeEventListener = function(o,e,l) { if (o.removeEventListener) { o.removeEventListener(e,l,false); } else if (o.detachEvent) { o.detachEvent('on'+e,function() { l(window.event); }); } } window.onload = function() { var oRect = new Rect(); oRect.addEventListener(oRect.doc , 'mousedown' , oRect.down); oRect.addEventListener(oRect.doc , 'mouseup' , oRect.up); } </script> </head> <body> <h1>拖动你的鼠标就会出现选择框</h1> </body> </html>
希望本文所述对大家的javascript程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程