真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎樣使用js實現(xiàn)百度登錄框鼠標(biāo)拖拽效果

這篇文章主要介紹怎樣使用js實現(xiàn)百度登錄框鼠標(biāo)拖拽效果,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)從2013年創(chuàng)立,先為肅州等服務(wù)建站,肅州等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為肅州企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

知識點(diǎn):

1.掌握對可拖拽對話框的實現(xiàn)原理

2.了解元素如何觸發(fā)腳本方法以及如何編寫偵聽事件

3. 學(xué)會設(shè)置元素在頁面中居中和全屏

注意區(qū)別:

1.screenX:鼠標(biāo)位置相對于用戶屏幕水平偏移量,而screenY也就是垂直方向的,此時的參照點(diǎn)也就是原點(diǎn)是屏幕的左上角。
2.clientX:跟screenX相比就是將參照點(diǎn)改成了瀏覽器內(nèi)容區(qū)域的左上角,該參照點(diǎn)會隨之滾動條的移動而移動。
3.pageX:參照點(diǎn)也是瀏覽器內(nèi)容區(qū)域的左上角,但它不會隨著滾動條而變動。

鼠標(biāo)事件:

鼠標(biāo)事件1 - 在標(biāo)題欄上按下(要計算鼠標(biāo)相對拖拽元素的左上角的坐標(biāo),并且標(biāo)記元素為可拖動)
鼠標(biāo)事件2 -  鼠標(biāo)移動時(要檢測元素是否標(biāo)記為可移動,如果是,則更新元素的位置到當(dāng)前鼠標(biāo)的位置【ps:要減去第一步中獲得的偏移】)
鼠標(biāo)事件3 - 鼠標(biāo)松開的時候(標(biāo)記元素為不可拖動即可)

效果:

怎樣使用js實現(xiàn)百度登錄框鼠標(biāo)拖拽效果

完整代碼及注釋:




 
 


 *{
 margin: 0;
 padding: 0;
 list-style: none;
 }
 .main{
 width: 600px;
 height: 320px;
 margin: 0 auto;
 margin-top: 80px;
 margin-left: 400px;
 }
 .img{
 text-align: center;
 }
 .item1{
 margin-left: 115px;
 width: 600px;
 }
 .item1 li{
 float: left;
 width: 50px;
 }
 .text{
 width: 600px;
 margin-left: 80px;
 margin-top: 5px;
 }
 .text .txt{
 width: 450px;
 height: 30px;
 }
 .text .btn{
 width: 70px;
 height: 30px;
 cursor: pointer;
 }
 .item2{
 width: 600px;
 margin-left: 200px;
 margin-top: 30px;
 }
 .item2 li{
 float: left;
 margin-left: 10px;
 }
 .link{
 text-align: right;
 line-height: 30px;
 padding-right: 40px;
 }
 .logmove{
 width: 380px;
 height: auto;
 background: #fff;

 }
 .Box{
 width: 380px;
 height: auto;
 position: absolute;
 left: 100px;
 top: 100px;
 border: 1px solid #d5d5d5;
 z-index: 9000;
 background: #fff;
 display: none;
 }
 .title{
 height: 48px;
 line-height: 48px;
 color: #535353;
 background: #f5f5f5;
 padding: 0px 20px;
 font-size: 16px;
 border-bottom: 1px solid #efefef;
 cursor: move;
 user-select: none;
 }
 .title .closebtn{
 display: block;
 width: 16px;
 height: 16px;
 position: absolute;
 top: 15px;
 right: 20px;
 background: url("img/close_def.png") no-repeat;
 cursor: pointer;
 }
 .title .closebtn:hover{
 background: url("img/close_hov.png");
 }
 .content{
 padding: 15px 20px;
 }
 .Input{
 padding-top: 15px;
 }
 .txt1,.txt2,.Input{
 height: 40px;
 line-height: 40px;
 text-align: right;
 }
 .username,.password{
 width: 100%;
 height: 40px;
 margin: 0px;
 padding: 0px;
 border: 1px solid #c1c1c1;
 text-indent: 25px;
 outline: none;
 }
 .username{
 background: url("img/input_username.png") no-repeat 2px;
 }
 .password{
 background: url("img/input_password.png") no-repeat 2px;
 }
 .submit{
 width: 100%;
 height: 50px;
 background: #3b7ae3;
 border: none;
 font-size: 16px;
 color: #fff;
 outline: none;
 text-decoration: none;
 display: block;
 text-align: center;
 line-height: 50px;
 }
 .submit:hover{
 background: #3f81b0;
 }
 .mask{
 width: 100%;
 height: 100%;
 background: #000;
 position: absolute;
 top: 0;
 left: 0;
 z-index: 8000;
 opacity: 0.4;
 filter: Alpha(opacity=40);
 display: none;
 }


 window.onload=function(){
 //獲取元素對象
 function g(id){
  return document.getElementById(id);
 }
 //自動居中 - 登錄浮層 ( el = Element)
 function autoCenter(el){
  var bodyW = document.documentElement.clientWidth;//網(wǎng)頁可視區(qū)域
  var bodyH = document.documentElement.clientHeight;
  var elW = el.offsetWidth;//登錄框的寬度
  var elH = el.offsetHeight;
  el.style.left = (bodyW - elW) / 2 + 'px';//實現(xiàn)居中
  el.style.top = (bodyH - elH) / 2 + 'px';
 }
 //自動全屏 - 遮罩
 function fillToBody(el){
  el.style.width = document.documentElement.clientWidth + 'px';
  el.style.height = document.documentElement.clientHeight + 'px';
 }
 var mouseOffsetX = 0;//鼠標(biāo)偏移量
 var mouseOffsetY = 0;
 var isDraging = false;
 //鼠標(biāo)事件1 - 在標(biāo)題欄上按下(要計算鼠標(biāo)相對拖拽元素的左上角的坐標(biāo),并且標(biāo)記元素為可拖動)
 g('title').addEventListener('mousedown',function(e){
  var e = e||window.event;
  mouseOffsetX = e.pageX - g('Box').offsetLeft;
  mouseOffsetY = e.pageY - g('Box').offsetTop;
  isDraging = true;
 })
 //鼠標(biāo)事件2 - 鼠標(biāo)移動時(要檢測元素是否標(biāo)記為可移動,如果是,則更新元素的位置到當(dāng)前鼠標(biāo)的位置【ps:要減去第一步中獲得的偏移】)
 document.onmousemove = function(e){
  var e = e||window.event;
  var mouseX = e.pageX;//鼠標(biāo)當(dāng)前位置
  var mouseY = e.pageY;
  var moveX = 0;//浮層元素的新位置
  var moveY = 0;
  if(isDraging === true){
  moveX = mouseX - mouseOffsetX;
  moveY = mouseY - mouseOffsetY;
  //拖拽范圍限定 moveX > 0 并且 moveX < (頁面最大寬度 - 浮層的寬度)
  //  moveY > 0 并且 moveY < (頁面最大高度 - 浮層的高度)
  var pageWidth = document.documentElement.clientWidth;//頁面寬度
  var pageHeight = document.documentElement.clientHeight;
  var BoxWidth = g('Box').offsetWidth;
  var BoxHeight = g('Box').offsetHeight;
  var maxX = pageWidth - BoxWidth;
  var maxY = pageHeight - BoxHeight;
  moveX = Math.max(0,moveX);//實際上就是獲得moveX的所有正數(shù)值,也就是規(guī)定范圍的下限值
  moveX = Math.min(maxX,moveX);//實際上就是規(guī)定了moveX的上限值
  moveY = Math.max(0,moveY);
  moveY = Math.min(maxY,moveY);
  /*
  moveX =Math.min(maxX, Math.max(0,moveX));
  moveY =Math.min(maxY, Math.max(0,moveY));
  */
  g('Box').style.left = moveX + 'px';
  g('Box').style.top = moveY + 'px';
  }
 }
 //鼠標(biāo)事件3 - 鼠標(biāo)松開的時候(標(biāo)記元素為不可拖動即可)
 document.onmouseup = function(){
  isDraging = false;
 }
 function showBox(){
  g('Box').style.display = 'block';
  g('mask').style.display = 'block';
  autoCenter(g('Box'));
  fillToBody(g('mask'));
 }
 function hideBox(){
  g('Box').style.display = 'none';
  g('mask').style.display = 'none';
 }
 g('log').onclick = function(){
  showBox();
 }
 g('close').onclick = function(){
  hideBox();
 }
 /*窗口改變大小時的處理
 1.保持登錄浮層居中
 2.保持遮罩的全屏,使之不會出現(xiàn)滾動條
 */
 window.onresize = function(){
  autoCenter(g('Box'));
  fillToBody(g('mask'));
 }
 }


登錄
 
     
   
         
     
  • 百科
  •  
  • 文庫
  •  
  • hao123
  •  
  • 更多>>
  •  
   登錄通行證                  忘記密碼    
 登錄  
   立即注冊  

以上是“怎樣使用js實現(xiàn)百度登錄框鼠標(biāo)拖拽效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


網(wǎng)頁題目:怎樣使用js實現(xiàn)百度登錄框鼠標(biāo)拖拽效果
鏈接URL:http://weahome.cn/article/jpccos.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部