javascript实现淡蓝色的鼠标拖动选择框实例


Posted in Javascript onMay 09, 2015

本文实例讲述了javascript实现淡蓝色的鼠标拖动选择框。分享给大家供大家参考。具体实现方法如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/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.top = currentY + 'px';
}
//document.title = "left:"+currentX + 'px '+"top:"+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.top = 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程序设计有所帮助。

Javascript 相关文章推荐
基于jQuery的仿flash的广告轮播
Nov 05 Javascript
js中判断文本框是否为空的两种方法
Jul 31 Javascript
IE下写xml文件的两种方式(fso/saveAs)
Aug 05 Javascript
客户端js性能优化小技巧整理
Nov 05 Javascript
使用javascript控制cookie显示和隐藏背景图
Feb 12 Javascript
jquery $(&quot;#variable&quot;) 循环改变variable的值示例
Feb 23 Javascript
JS在可编辑的div中的光标位置插入内容的方法
Nov 20 Javascript
JS实现六位字符密码输入器功能
Aug 19 Javascript
浅析JavaScript动画模拟拖拽原理
Dec 09 Javascript
解决Vue.js由于延时显示了{{message}}引用界面的问题
Aug 25 Javascript
vue 插件的方法代码详解
Jun 06 Javascript
浅谈TypeScript 索引签名的理解
Oct 16 Javascript
javasript实现密码的隐藏与显示
May 08 #Javascript
jquery实现动态改变div宽度和高度
May 08 #Javascript
jquery右下角自动弹出可关闭的广告层
May 08 #Javascript
jQuery实现鼠标经过图片变亮其他变暗效果
May 08 #Javascript
JavaScript实现自动变换表格边框颜色
May 08 #Javascript
JavaScript基于setTimeout实现计数的方法
May 08 #Javascript
jQuery基于图层模仿五星星评价功能的方法
May 07 #Javascript
You might like
再说下636单管机
2021/03/02 无线电
PHP中文乱码解决方案
2015/03/05 PHP
使用WAMP搭建PHP本地开发环境
2017/05/10 PHP
PHP实现基于3DES算法加密解密字符串示例
2018/08/24 PHP
在JavaScript中实现命名空间
2006/11/23 Javascript
根据地区不同显示时间的javascript代码
2007/08/13 Javascript
NodeJS 模块开发及发布详解分享
2012/03/07 NodeJs
JS小功能(操作Table--动态添加删除表格及数据)实现代码
2013/11/28 Javascript
Js保留小数点的4种效果实现代码分享
2014/04/12 Javascript
jQuery Migrate 1.1.0 Released 注意事项
2014/06/14 Javascript
jquery中append()与appendto()用法分析
2014/11/14 Javascript
深入分析js的冒泡事件
2014/12/05 Javascript
全面解析Bootstrap表单使用方法(表单样式)
2015/11/24 Javascript
indexedDB bootstrap angularjs之 MVC DOMO (应用示例)
2016/06/20 Javascript
AngularJS动态菜单操作指令
2017/04/25 Javascript
快速解决vue-cli不能初始化webpack模板的问题
2018/03/20 Javascript
Node.js中的cluster模块深入解读
2018/06/11 Javascript
原生JS实现获取及修改CSS样式的方法
2018/09/04 Javascript
JQueryDOM之样式操作
2019/03/27 jQuery
[06:45]DOTA2卡尔工作室 英雄介绍幻影长矛手篇
2013/07/12 DOTA
[02:36]DOTA2上海特锦赛 回忆电竞生涯的重要瞬间
2016/03/25 DOTA
python实现矩阵乘法的方法
2015/06/28 Python
python Spyder界面无法打开的解决方法
2018/04/27 Python
python 日期操作类代码
2018/05/05 Python
Python subprocess模块常见用法分析
2018/06/12 Python
Python批处理更改文件名os.rename的方法
2018/10/26 Python
Python编写带选项的命令行程序方法
2019/08/13 Python
Python通过format函数格式化显示值
2020/10/17 Python
Reebok官方旗舰店:美国知名健身品牌锐步
2019/01/07 全球购物
请写出 float x 与"零值"比较的 if 语句
2016/01/04 面试题
Does C# support multiple inheritance? (C#支持多重继承吗)
2012/01/04 面试题
路政管理专业推荐信
2013/11/11 职场文书
公务员政审个人鉴定
2014/02/25 职场文书
工程款申请报告
2015/05/15 职场文书
解决vue-router的beforeRouteUpdate不能触发
2022/04/14 Vue.js
Java设计模式之代理模式
2022/04/22 Java/Android