婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > HTML 拖拉功能的實現代碼

HTML 拖拉功能的實現代碼

熱門標簽:重慶人工智能電銷機器人報價 愛巢地圖標注 長春極信防封電銷卡公司 貴陽ai外呼系統 電話機器人批發 強訊外呼系統 智能電銷機器人廣告語 電銷外呼線路改不外呼線路 crm外呼系統好不好

基于 vue

此功能核心思想就是通過 JavaScript 代碼控制 node 在頁面上的左邊距與頂邊距,不同的的樣式定位方式有不同的解決方案

本方案采用position: absolute定位方式的解決方案

css 樣式的核心代碼

// 父容器核心樣式

  width: 100%;
  height: 100%;
// 子容器核心樣式
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);

父容器通過width && height字段占滿整個瀏覽器的可視范圍,子容器通過position: absolute屬性開啟在父容器內的絕對定位,在通過top && left && transform: translate(-50%, -50%)屬性控制子容器在父容器內的絕對位置

JavaScript 邏輯控制的核心代碼

首先分解下,要實現 node 的移動需要哪些步驟和對應的 event 事件

  • 子容器創建時,在父容器內的絕對位置
  • 鼠標按鍵按下時,onmousedown 事件
  • 鼠標移動時,onmousemove 事件
  • 鼠標按鍵彈起時,onmouseup 事件

只要使用 onMousedown、onMousemove和onMouseup 這三個事件,就可以實現最簡單的移動

/*
* 在子容器創建的時候獲取子容器相對于父容器的 top 和 left 位置
*/

mounted () {
  this.left = this.$refs.fatherBox.offsetLeft
  this.top = this.$refs.fatherBox.offsetTop
}
/*
* 鼠標按下時
* 1. 開啟允許子容器移動的 flag
* 2. 記錄鼠標點擊時的位置信息
*/

mouseDown (e) {
  // 設置允許彈窗移動的 flag
  this.moveFlag = true
  // 保存鼠標開始位置
  this.startLeft = e.clientX - this.left
  this.startTop = e.clientY - this.top
}
/*
* 鼠標移動時
* 1. 判斷 flag 是否允許子容器移動
* 2. 設置彈框左邊位置
* 3. 設置彈框右邊位置
*/

move (e) {
  // 判斷 flag 是否允許移動
  if (!this.moveFlag) return

  // 設置彈框左邊位置
  this.left = e.clientX - this.startLeft
  // 設置彈框右邊位置
  this.top = e.clientY - this.startTop

}
/*
* 鼠標按鍵彈起時
* 1. 關閉允許子容器移動的 flag
*/

mouseUp (e) {
  this.flag = false
}

通過這幾個方法就可以獲取鼠標按下移動時,鼠標的top 和 left 的偏移量,通過把這偏移量暴露出去給父組件,父組件實時設置子組件的 top 和 left 值,來使得子容器跟隨鼠標的移動

父組件部分代碼

父組件通過設置子組件的 ref、zIndex 值,而且父組件的 backValue 方法會從子組件接收 zIndex 值,通過 zIndex 來識別具體的子組件實例

/*
* 父組件代碼片段 jsx 版
*/

export default {
  props: {
    playList: {
      type: Array,
      required: true
    }
  },
  render () {
    return (
      <div style={{width: '100%', height: '100%'}} ref={'father'}>
        {
          this.playList && this.playList.map((item, index) => {
            return (
              <ChildComponents
                key={index}
                ref={index}
                zIndex={index}
                visible={true}
                backValue={this.backValue}
                info={item}
                width={600}
                height={400}
              />
            )
          })
        }
      </div>
    )
  },
  methods: {
    backValue (left, top, zIndex) {
      this.$refs[zIndex].$el.style.top = `${top}px`
      this.$refs[zIndex].$el.style.left = `${left}px`
    }
  }
}
<!-- 父組件代碼片段 vue 文件版 -->

<template>
  <div
    ref="father"
    style"width: 100%, height: 100%"
  >
    <ChildComponents
      v-for="(item, index) in playList"
      :key="index"
      :ref="index"
      :visible="true"
      :z-index="index"
      :back-value="backValue"
      :info="item"
      :close="close"
      :width="600"
      :height="400"
    />
  </div>
</template>
<script>
export default {
  components: {
    VideoPlayerModal
  },
  props: {
    playList: {
      type: Array,
      required: true
    }
  },
  methods: {
    backValue (left, top, zIndex) {
      this.$refs[zIndex][0].$el.style.top = `${top}px`
      this.$refs[zIndex][0].$el.style.left = `${left}px`
    }
  }
}
</script>

設置子組件的圍欄范圍

這個功能只需要在 onmousemove 事件中進行判斷 子容器的 top 和 left 是否超出瀏覽器的可視范圍

/*
* 1. this.width 數據為父組件傳遞進來的 width 值,或者子組件本身設置的默認值
* 2. this.height 數據為父組件傳遞進來的 height 值,或者子組件本身設置的默認值
*/

move (e) {
  // 判斷 flag 是否允許移動
  if (!this.moveFlag) return

  // 判斷是否超出左邊視圖
      if (this.$refs.fatherBox.offsetLeft < this.width / 2) {
        // 禁止彈框移動
        this.moveFlag = false
        // 設置彈框左邊位置
        this.left = this.width / 2 + 10
        // 調用回調函數把偏移量暴露給父組件
        this.backValue(this.left, this.top, this.zIndex)
        return
      }

      // 判斷是否超出右邊視圖
      if (this.$refs.fatherBox.offsetLeft > document.body.clientWidth - this.width / 2) {
        // 禁止彈框移動
        this.moveFlag = false
        // 設置彈框右邊位置
        this.left = document.body.clientWidth - this.width / 2 - 10
        // 調用回調函數把偏移量暴露給父組件
        this.backValue(this.left, this.top, this.zIndex)
        return
      }

      // 判斷是否超出頂部視圖
      if (this.$refs.fatherBox.offsetTop < this.height / 2 + 70) {
        // 禁止彈框移動
        this.moveFlag = false
        // 設置彈框頂部位置
        this.top = this.height / 2 + 70 + 10
        // 調用回調函數把偏移量暴露給父組件
        this.backValue(this.left, this.top, this.zIndex)
        return
      }

      // 判斷是否超出底部視圖
      if (this.$refs.fatherBox.offsetTop > document.body.clientHeight - this.height / 2 - 50) {
        // 禁止彈框移動
        this.moveFlag = false
        // 設置彈框底部位置
        this.top = document.body.clientHeight - this.height / 2 - 50 - 10
        // 調用回調函數把偏移量暴露給父組件
        this.backValue(this.left, this.top, this.zIndex)
        return
      }

      // 設置彈框左邊位置
      this.left = e.clientX - this.startLeft
      // 設置彈框右邊位置
      this.top = e.clientY - this.startTop

      // 調用回調函數把偏移量暴露給父組件
      this.backValue(this.left, this.top, this.zIndex)
}

子組件還要設置一個當鼠標超出子容器時的 onmouseout 事件,用來防止不可預期的 bug 問題

mouseOut (e) {
  this.moveFlag = false
}

到此這篇關于HTML 拖拉功能的文章就介紹到這了,更多相關HTML 拖拉功能內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:陜西 山南 清遠 保定 吳忠 廣安 內蒙古 上海

巨人網絡通訊聲明:本文標題《HTML 拖拉功能的實現代碼》,本文關鍵詞  HTML,拖拉,功能,的,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML 拖拉功能的實現代碼》相關的同類信息!
  • 本頁收集關于HTML 拖拉功能的實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产网站一区二区| 久久奇米777| 亚洲一区二区三区四区不卡| 欧美大胆一级视频| 在线观看亚洲a| 日韩激情av在线| 国产精品久久久久四虎| 日韩午夜电影av| 91精品欧美一区二区三区综合在| 99久久久国产精品免费蜜臀| 国产福利一区在线| 国产成人亚洲精品青草天美| 国产麻豆午夜三级精品| 日韩制服丝袜av| 亚洲精品乱码久久久久久久久| 国产精品女同互慰在线看| 国产精品亲子乱子伦xxxx裸| 亚洲国产精品ⅴa在线观看| 精品国产乱码久久久久久久| 精品成人一区二区三区| 欧美日韩成人综合| 欧美一区二区三区白人| 欧美成人精品二区三区99精品| 欧美丰满少妇xxxbbb| 99国产精品久久久久久久久久久| 色偷偷久久一区二区三区| 欧美一级高清大全免费观看| 宅男在线国产精品| 91精品欧美久久久久久动漫| 51久久夜色精品国产麻豆| 在线成人高清不卡| 日韩欧美国产综合| 国产亚洲精品aa午夜观看| 国产精品不卡一区| 亚洲mv在线观看| 日本成人在线看| 粉嫩久久99精品久久久久久夜 | 91成人网在线| 538prom精品视频线放| 久久午夜电影网| 久久免费午夜影院| 一区二区三区免费看视频| 亚洲va欧美va人人爽| 日韩精品免费专区| 国产伦精品一区二区三区视频青涩 | 日韩欧美另类在线| 欧美精品久久久久久久久老牛影院 | 日韩亚洲欧美一区二区三区| 国产日韩欧美精品综合| 极品少妇xxxx偷拍精品少妇| 精品久久久久久久人人人人传媒| 一区二区三区中文字幕电影 | 国产日韩精品一区| 成人爽a毛片一区二区免费| 精品蜜桃在线看| 久久综合九色综合97_久久久| 成人av免费观看| 最新中文字幕一区二区三区| 在线免费观看日韩欧美| 日本亚洲一区二区| 精品久久久久久久久久久院品网 | 精品一区二区三区香蕉蜜桃 | 亚洲高清视频中文字幕| 91免费国产在线| 开心九九激情九九欧美日韩精美视频电影| 久久精品久久综合| 在线视频观看一区| 欧美成人a视频| 亚洲欧洲精品一区二区三区不卡| 亚洲综合丝袜美腿| 激情久久五月天| 欧美高清视频一二三区 | 国产亚洲精品精华液| 亚洲午夜国产一区99re久久| 欧美三级蜜桃2在线观看| 国产精品一区三区| 91精品国产手机| 性欧美大战久久久久久久久| 久久国产麻豆精品| 欧美精品1区2区| 日韩二区三区四区| 欧美一级国产精品| 青青草97国产精品免费观看无弹窗版 | 97久久精品人人做人人爽| 91美女片黄在线观看| 北条麻妃国产九九精品视频| 色天天综合久久久久综合片| 尤物视频一区二区| 高清不卡一二三区| 亚洲黄色免费网站| 成人久久久精品乱码一区二区三区| 亚洲图片激情小说| 91精品一区二区三区久久久久久| 天天爽夜夜爽夜夜爽精品视频| 欧美精品xxxxbbbb| 成人蜜臀av电影| 亚洲成人av一区二区| 337p日本欧洲亚洲大胆色噜噜| 国产成人高清视频| 亚洲天堂av一区| 精品国产青草久久久久福利| 成人性生交大片免费看视频在线| 伊人夜夜躁av伊人久久| 国产午夜三级一区二区三| 91福利资源站| 91麻豆国产香蕉久久精品| 国产一区二区三区| 日韩经典一区二区| 亚洲第一久久影院| 国产精品天干天干在线综合| 国产欧美日本一区视频| 国产精品乱码一区二区三区软件 | 欧美一区二区大片| 99久久99久久免费精品蜜臀| 精品无人码麻豆乱码1区2区 | 男女男精品视频| 五月综合激情网| 夜夜爽夜夜爽精品视频| 亚洲欧洲成人av每日更新| 中文乱码免费一区二区| 国产精品久久一级| 亚洲免费av网站| 中文字幕在线观看不卡视频| 国产真实乱偷精品视频免| 日本成人中文字幕| 国产一区二区网址| 国产精品77777| 久久久久9999亚洲精品| 日韩欧美一二三区| 国产精品乱码妇女bbbb| 亚洲一区中文在线| 久久精品国产澳门| 波多野结衣在线aⅴ中文字幕不卡| 懂色av中文字幕一区二区三区| a级精品国产片在线观看| 91亚洲国产成人精品一区二区三| 色噜噜狠狠色综合欧洲selulu| 日本韩国欧美三级| 久久综合色综合88| 1000部国产精品成人观看| 日本sm残虐另类| 在线精品视频一区二区| 久久久久久久久免费| 国产精品久久久久国产精品日日| 欧美日韩一区 二区 三区 久久精品| 亚洲大片免费看| 国产又黄又大久久| 欧美日韩视频在线观看一区二区三区 | 亚洲免费三区一区二区| 亚洲18影院在线观看| 日韩午夜在线观看| 欧美成人三级在线| 国产精品国产三级国产aⅴ原创 | 国产一级精品在线| 在线不卡免费av| 久久97超碰色| 91精品国产综合久久久蜜臀粉嫩| 中文字幕在线不卡一区 | 精品99一区二区三区| 日韩一区二区在线观看视频| 高清成人免费视频| 欧美日韩国产综合一区二区三区| 亚洲人成网站色在线观看 | 国产欧美日韩综合精品一区二区| 午夜精品久久久| 精品国内二区三区| 91国偷自产一区二区三区观看| 奇米色777欧美一区二区| 亚洲国产日韩一级| 亚洲精品高清在线| 亚洲综合av网| 日韩电影在线一区二区三区| 日韩精品电影在线观看| 丝瓜av网站精品一区二区| 午夜影视日本亚洲欧洲精品| 国产99久久久国产精品潘金| 777精品伊人久久久久大香线蕉| 欧美日韩亚洲综合在线| 精品嫩草影院久久| 最新国产成人在线观看| 亚洲成人av在线电影| 久久99国内精品| 欧美午夜精品久久久久久超碰| 欧美大片拔萝卜| 亚洲综合在线电影| 国产精品中文有码| 欧美二区乱c少妇| 国产天堂亚洲国产碰碰| 亚洲狠狠丁香婷婷综合久久久| 国产中文一区二区三区| 欧美三级在线看| 亚洲欧美一区二区三区国产精品 | 欧美电影在哪看比较好| 中文幕一区二区三区久久蜜桃| 久久精品国产在热久久| 欧美日韩国产美女| 亚洲精品综合在线| 在线亚洲一区二区| 亚洲免费在线视频| www.爱久久.com|