JS拖动鼠标画出方框实现鼠标选区的方法


Posted in Javascript onAugust 05, 2015

本文实例讲述了JS拖动鼠标画出方框实现鼠标选区的方法。分享给大家供大家参考。具体如下:

相当实用的一个JS技巧,拖动鼠标可画出一个方框,可作为一个选区的功能,可以用来画流程图,设计草图什么的,也可以作为上传头像时裁切选择图片,在头像裁切中使用广泛,鼠标在图片上拖动拉出一个方框,这个方框就代表着选区的功能,目前网页上已流行的一种操作。主要是依赖于JavaScript代码来实现。

运行效果如下图所示:

JS拖动鼠标画出方框实现鼠标选区的方法

具体代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh" lang="zh">
<head>
<title>鼠标拖动画矩形</title>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<style type="text/css">
body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,form,fieldset,legend,button,input,textarea,th,td{margin:0;padding:0}
html{color:#000;overflow-y:scoll;overflow:-moz-scrollbars-vertical}
.div{position:absolute; border:1px dashed blue; width:0px; height:0px;left:0px; top:0px; overflow:hidden;}
.retc{position:absolute; border:1px solid #CCCCCC; overflow:hidden; background:#EFEFEF}
</style>
</head>
<body> 
</body>
<script language = "javascript">
 var wId = "w";
 var index = 0;
 var startX = 0, startY = 0;
 var flag = false;
 var retcLeft = "0px", retcTop = "0px", retcHeight = "0px", retcWidth = "0px";
 document.onmousedown = function(e){
  flag = true;
  try{
   var evt = window.event || e;
   var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
   var scrollLeft = document.body.scrollLeft || document.documentElement.scrollLeft;
   startX = evt.clientX + scrollLeft;
   startY = evt.clientY + scrollTop;
   index++;
   var div = document.createElement("div");
   div.id = wId + index;
   div.className = "div";
   div.style.marginLeft = startX + "px";
   div.style.marginTop = startY + "px";
   document.body.appendChild(div);
  }catch(e){
  //alert(e);
  }
 }
 document.onmouseup = function(){
  try{
   document.body.removeChild($(wId + index));
   var div = document.createElement("div");
   div.className = "retc";
   div.style.marginLeft = retcLeft;
   div.style.marginTop = retcTop;
   div.style.width = retcWidth;
   div.style.height = retcHeight;
   document.body.appendChild(div);
  }catch(e){
   //alert(e);
  }
  flag = false;
 }
 document.onmousemove = function(e){
  if(flag){
   try{
   var evt = window.event || e;
   var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
   var scrollLeft = document.body.scrollLeft || document.documentElement.scrollLeft;
   retcLeft = (startX - evt.clientX - scrollLeft > 0 ? evt.clientX + scrollLeft : startX) + "px";
   retcTop = (startY - evt.clientY - scrollTop > 0 ? evt.clientY + scrollTop : startY) + "px";
   retcHeight = Math.abs(startY - evt.clientY - scrollTop) + "px";
   retcWidth = Math.abs(startX - evt.clientX - scrollLeft) + "px";
   $(wId + index).style.marginLeft = retcLeft;
   $(wId + index).style.marginTop = retcTop;
   $(wId + index).style.width = retcWidth;
   $(wId + index).style.height = retcHeight;
   }catch(e){
    //alert(e);
   } 
  }
 }
 var $ = function(id){
  return document.getElementById(id);
 }
</script>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
JQuery困惑—包装集 DOM节点
Oct 16 Javascript
提交表单时执行func方法实现代码
Mar 17 Javascript
extjs关于treePanel+chekBox全部选中以及清空选中问题探讨
Apr 02 Javascript
Jquery中CSS选择器用法分析
Feb 10 Javascript
jQuery实现新消息闪烁标题提示的方法
Mar 11 Javascript
浅谈window.onbeforeunload() 事件调用ajax
Jun 29 Javascript
bootstrap+jQuery实现的动态进度条功能示例
May 25 jQuery
详解动画插件wow.js的使用方法
Sep 13 Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
Nov 11 Javascript
ng-alain的sf如何自定义部件的流程
Jun 12 Javascript
JavaScript中跨域问题的深入理解
Mar 04 Javascript
详解TS数字分隔符和更严格的类属性检查
May 06 Javascript
JS绘制生成花瓣效果的方法
Aug 05 #Javascript
JS实现点击上移下移LI行数据的方法
Aug 05 #Javascript
将页面table内容与样式另存成excel文件的方法
Aug 05 #Javascript
JS模拟键盘打字效果的方法
Aug 05 #Javascript
js点击列表文字对应该行显示背景颜色的实现代码
Aug 05 #Javascript
JS使用parseInt解析数字实现求和的方法
Aug 05 #Javascript
js绘制圆形和矩形的方法
Aug 05 #Javascript
You might like
用php来检测proxy
2006/10/09 PHP
php实现给图片加灰色半透明效果的方法
2014/10/20 PHP
PHP反射原理与用法深入分析
2019/09/28 PHP
在Laravel中实现使用AJAX动态刷新部分页面
2019/10/15 PHP
利用js动态添加删除table行的示例代码
2013/12/16 Javascript
原生js的弹出层且其内的窗口居中
2014/05/14 Javascript
js去除输入框中所有的空格和禁止输入空格的方法
2014/06/09 Javascript
Node.js 文件夹目录结构创建实例代码
2016/07/08 Javascript
微信开发 JS-SDK 6.0.2 经常遇到问题总结
2016/12/08 Javascript
详解Sea.js中Module.exports和exports的区别
2017/02/12 Javascript
浅析JavaScript中var that=this
2017/02/17 Javascript
单行 JS 实现移动端金钱格式的输入规则
2017/05/22 Javascript
如何理解Vue的v-model指令的使用方法
2018/07/19 Javascript
详解在网页上通过JS实现文本的语音朗读
2019/03/28 Javascript
Vue-Cli 3.0 中配置高德地图的两种方式
2019/06/19 Javascript
node解析修改nginx配置文件操作实例分析
2019/11/06 Javascript
微信小程序关键字变色实现代码实例
2019/12/13 Javascript
[02:08]2014DOTA2国际邀请赛 430专访:力争取得小组前二
2014/07/11 DOTA
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
python 巧用正则寻找字符串中的特定字符的位置方法
2018/05/02 Python
Django用户认证系统 User对象解析
2019/08/02 Python
python 计算方位角实例(根据两点的坐标计算)
2020/01/17 Python
如何在python中执行另一个py文件
2020/04/30 Python
如何用python开发Zeroc Ice应用
2021/01/29 Python
python中Array和DataFrame相互转换的实例讲解
2021/02/03 Python
欧洲第一的摇滚和金属乐队服装网站:EMP
2017/10/26 全球购物
英国领先的互联网葡萄酒礼品商:Vintage Wine & Port
2019/05/24 全球购物
亚洲颇具影响力的男性在线购物零售商:His
2019/11/24 全球购物
自我鉴定的范文
2013/10/03 职场文书
物流专业大学生的自我鉴定
2013/11/13 职场文书
银行职业规划书范文
2013/12/28 职场文书
个人四风问题对照检查材料
2014/09/26 职场文书
2015年加油站站长工作总结
2015/05/27 职场文书
订货会主持词
2015/07/01 职场文书
离职员工给领导和同事的感谢信
2015/11/03 职场文书
2016年小学优秀班主任事迹材料
2016/02/29 职场文书