欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3實(shí)現(xiàn)移動端滑動模塊

 更新時間:2022年09月14日 15:26:50   作者:如光不息丶  
這篇文章主要為大家詳細(xì)介紹了vue3實(shí)現(xiàn)移動端滑動模塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了vue3實(shí)現(xiàn)移動端滑動模塊的具體代碼,供大家參考,具體內(nèi)容如下

需要實(shí)現(xiàn)的需求如下

直接上代碼

HTML:

<div class="container" id="container">
? <div class="controlDiv" id="controlDiv">
? ? <div?
? ? ? class="centerCircle"?
? ? ? id="centerCircle"?
? ? ? @touchstart="start"?
? ? ? @touchmove="move"?
? ? ? @touchend="end">
? ? </div>
? </div>
</div>

javascript:

import {defineComponent, onMounted} from "vue";
export default defineComponent({
? setup(prop,content) {
? ? let controlDiv ='' //控制器容器元素
? ? let circleDiv = '' //中心圓元素
? ? //最大寬高
? ? let maxW = 0
? ? let maxH = 0
? ? //初始觸摸點(diǎn)
? ? let oL = 0
? ? let oT = 0
? ? //相對屏幕的初始觸摸點(diǎn)
? ? let touchClientX = 0?
? ? let touchClientY = 0

? ? onMounted(() => {
? ? ? controlDiv = document.querySelector('#controlDiv') //控制器容器元素
? ? ? circleDiv = document.querySelector('#centerCircle') //中心圓元素
? ? ? console.log(circleDiv.offsetWidth, circleDiv.offsetHeight)

? ? ? //限制最大寬高,不讓滑塊出去
? ? ? maxW = controlDiv.offsetWidth
? ? ? maxH = controlDiv.offsetHeight
? ? })

? ? //手指觸摸開始,記錄div的初始位置
? ? const start = (e) => {
? ? ? var ev = e || window.event;
? ? ? var touch = ev.targetTouches[0];
? ? ? //初始位置
? ? ? oL = touch.clientX - circleDiv.offsetLeft
? ? ? oT = touch.clientY - circleDiv.offsetTop

? ? ? touchClientX = touch.clientX
? ? ? touchClientY = touch.clientY

? ? ? console.log(oL, oT)
? ? ? //阻止瀏覽器滑動默認(rèn)行為
? ? ? document.addEventListener('touchmove', defaultEvent, { passive: false })
? ? }

? ? //手指滑動并改變滑塊位置
? ? const move = (e) => {
? ? ? var ev = e || window.event
? ? ? var touch = ev.targetTouches[0]
? ? ? var oLeft = touch.clientX - oL
? ? ? var oTop = touch.clientY - oT

? ? ? //判斷是否超出邊界
? ? ? if(oLeft - 30 < 0) {
? ? ? ? ? oLeft = 30
? ? ? } else if(oLeft + 30 >= maxW) {
? ? ? ? ? oLeft = maxW-30
? ? ? }
? ? ? if(oTop - 30 < 0) {
? ? ? ? ? oTop = 30
? ? ? } else if(oTop + 30 >= maxH) {
? ? ? ? ? oTop = maxH-30
? ? ? }

? ? ? //通過正切函數(shù)
? ? ? let tan = (150 - oTop)/(oLeft - 150)
? ? ? // console.log(tan)

? ? ? // circleDiv.style.transition = '.1s all' //動畫效果(體驗(yàn)不佳,不建議使用)

? ? ? //判斷中心位置上下左右20px范圍可隨意滑動
? ? ? if(Math.abs(oLeft - 150) >= 20 || Math.abs(150 - oTop)>= 20){
? ? ? ? // 通過正切函數(shù)判斷滑塊該在X軸上移動或是y軸上移動
? ? ? ? if((tan <= -1) || (tan >= 1)){ //y軸
? ? ? ? ? circleDiv.style.top = ?oTop + 'px'
? ? ? ? ? circleDiv.style.left = ?150 + 'px'
? ? ? ? }else if((tan > -1) || (tan < 1)){ //x軸
? ? ? ? ? circleDiv.style.top = 150 + 'px'
? ? ? ? ? circleDiv.style.left = oLeft + 'px'
? ? ? ? }
? ? ? }else{
? ? ? ? circleDiv.style.top = ?oTop + 'px'
? ? ? ? circleDiv.style.left = oLeft + 'px'
? ? ? }
? ? }

? ? //手指抬起
? ? const end = (e) => {
? ? ? //回彈初始點(diǎn)
? ? ? circleDiv.style.left = (touchClientX - ?oL) + 'px'
? ? ? circleDiv.style.top = (touchClientY - oT) + 'px'

? ? ? //恢復(fù)瀏覽器滑動默認(rèn)行為
? ? ? document.removeEventListener("touchmove", defaultEvent, { passive: true })
? ? }

? ? //阻止默認(rèn)事件
? ? function defaultEvent(e) {
? ? ? e.preventDefault();
? ? }

? ? return { start, move, end }
? }
});

CSS:

.controlDiv{
? position: relative;
? width: 300px;
? height: 300px;
? background: #ebebeb;
? margin: 200px auto;
? border-radius: 50%;
?}
.centerCircle{
? width: 65px;
? height: 65px;
? background: #fff;
? position: absolute;
? top: 50%;
? left: 50%;
? transform: translate(-50%, -50%);
? border-radius: 50%;
? box-shadow:0px 0px 30px #a7a7a7;
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3 style CSS 變量注入的實(shí)現(xiàn)

    Vue3 style CSS 變量注入的實(shí)現(xiàn)

    本文主要介紹了Vue3 style CSS 變量注入的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • Vue組件的Prop命名約定詳解

    Vue組件的Prop命名約定詳解

    這篇文章主要為大家介紹了Vue組件的Prop命名約定詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 淺談vue引用靜態(tài)資源需要注意的事項(xiàng)

    淺談vue引用靜態(tài)資源需要注意的事項(xiàng)

    今天小編就為大家分享一篇淺談vue引用靜態(tài)資源需要注意的事項(xiàng),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • clipboard在vue中的使用的方法示例

    clipboard在vue中的使用的方法示例

    這篇文章主要介紹了clipboard在vue中的使用的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • Vue中以HTML形式顯示內(nèi)容并動態(tài)生成HTML代碼的方法

    Vue中以HTML形式顯示內(nèi)容并動態(tài)生成HTML代碼的方法

    有的時候我們想在vue中直接顯示一個html的網(wǎng)頁,如果用富文本方式,那么內(nèi)容就會太多,那么怎么處理呢?這篇文章主要給大家介紹了關(guān)于Vue中如何以HTML形式顯示內(nèi)容并動態(tài)生成HTML代碼的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • js數(shù)組的 entries() 獲取迭代方法

    js數(shù)組的 entries() 獲取迭代方法

    這篇文章主要介紹了js數(shù)組的 entries() 獲取迭代方法,entries() 方法返回一個數(shù)組的迭代對象,該對象包含數(shù)組的鍵值對 (key/value)。下面來詳細(xì)介紹該neural,需要的朋友可以參考一下
    2021-10-10
  • 在vue-cli的組件模板里使用font-awesome的兩種方法

    在vue-cli的組件模板里使用font-awesome的兩種方法

    今天小編就為大家分享一篇在vue-cli的組件模板里使用font-awesome的兩種方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 深度解讀vue-resize的具體用法

    深度解讀vue-resize的具體用法

    這篇文章主要介紹了vue-resize深度解讀,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Vue調(diào)用后端java接口的實(shí)例代碼

    Vue調(diào)用后端java接口的實(shí)例代碼

    今天小編就為大家分享一篇Vue調(diào)用后端java接口的實(shí)例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue3中reactive丟失響應(yīng)式問題詳解

    Vue3中reactive丟失響應(yīng)式問題詳解

    在vue3中,如果你用reactive聲明了一個對象,用另一個對象直接給它賦值,那么它就會失去響應(yīng)式,下面這篇文章主要給大家介紹了關(guān)于Vue3中reactive丟失響應(yīng)式問題的相關(guān)資料,需要的朋友可以參考下
    2023-03-03

最新評論