国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JS拖動鼠標畫出方框實現鼠標選區的方法

2019-11-20 11:54:45
字體:
來源:轉載
供稿:網友

本文實例講述了JS拖動鼠標畫出方框實現鼠標選區的方法。分享給大家供大家參考。具體如下:

相當實用的一個JS技巧,拖動鼠標可畫出一個方框,可作為一個選區的功能,可以用來畫流程圖,設計草圖什么的,也可以作為上傳頭像時裁切選擇圖片,在頭像裁切中使用廣泛,鼠標在圖片上拖動拉出一個方框,這個方框就代表著選區的功能,目前網頁上已流行的一種操作。主要是依賴于JavaScript代碼來實現。

運行效果如下圖所示:

具體代碼如下:

<!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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 博白县| 永吉县| 平阳县| 游戏| 绥阳县| 黄浦区| 波密县| 华阴市| 阳泉市| 灵丘县| 田阳县| 卢氏县| 广西| 安福县| 琼海市| 皋兰县| 辰溪县| 博爱县| 平度市| 手机| 康马县| 东丰县| 常宁市| 崇阳县| 望城县| 阳城县| 永兴县| 罗定市| 寿光市| 长乐市| 宜城市| 大关县| 永靖县| 东乡族自治县| 阿克| 新巴尔虎左旗| 田阳县| 高要市| 巴彦淖尔市| 揭西县| 东乌珠穆沁旗|