日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼

瀏覽:193日期:2023-01-31 13:18:10

懸浮球插件簡單的效果圖:

很遺憾,沒找到太好的視頻轉(zhuǎn)gif的軟件,壓縮出來的大小超過了限制,就不放圖了

可以參考其他人的圖,效果一致:

Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼

簡單實(shí)用案例:

<!-- 給定一個初始位置position,插槽中填寫想滑動的部分 --><xuanfuqiu :position='position'><d-add-button @click='addPigFarm' add-item='豬場'></d-add-button></xuanfuqiu>

原理示意圖

請結(jié)合代碼注釋來理解

Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼

懸浮球插件代碼如下:

<template> <div> <div : @mousedown='down' @touchstart='down' @mousemove='move' @touchmove='move' @mouseup='end' @touchend='end'> <slot></slot> </div> </div></template><script>export default { name: '', components: {}, props: { // 通過position來設(shè)置初始定位 position: { type: Object, default: function() {return { top: '32.25rem', left: '18.34375rem'} } }, // 通過fixed來禁用自由移動 fixed: { type: Boolean, default: false } }, data() { return { flags: false, positionTemp: { x: 0, y: 0 }, // 記錄手指點(diǎn)擊的位置 nx: ’’, ny: ’’, dx: ’’, dy: ’’, xPum: ’’, yPum: ’’, } }, watch: {}, computed: {}, methods: { // 實(shí)現(xiàn)移動端拖拽 down(){ if (this.fixed) {return } this.flags = true; var touch; // 該if判斷是用touch還是mouse來移動 if (event.touches) {touch = event.touches[0]; } else {touch = event; } this.positionTemp.x = touch.clientX; // 手指點(diǎn)擊后的位置 this.positionTemp.y = touch.clientY; this.dx = moveDiv.offsetLeft; // 移動的div元素的位置 this.dy = moveDiv.offsetTop; // console.log('moveDiv.offsetLeft', moveDiv.offsetLeft) // console.log('touch.clientX', touch.clientX) }, move(){ if(this.flags) {var touch ;if(event.touches){ touch = event.touches[0];}else { touch = event;}this.nx = touch.clientX - this.positionTemp.x; // 手指移動的變化量this.ny = touch.clientY - this.positionTemp.y;this.xPum = this.dx + this.nx; // 移動后,div元素的位置this.yPum = this.dy + this.ny;let windowWidth = document.documentElement.clientWidthlet windowHeight = document.documentElement.clientHeight// console.log('window.clientWidth', windowWidth)// console.log(this.xPum)// console.log(' moveDiv.clientWidth', moveDiv.clientWidth)if (this.xPum > 0 && (this.xPum + moveDiv.clientWidth < windowWidth)) {// movediv的左右邊,未出界 moveDiv.style.left = this.xPum + 'px';} else if (this.xPum <= 0) { // 左邊出界,則左邊緣貼邊 moveDiv.style.left = 0 + 'px';} else if (this.xPum + moveDiv.clientWidth >= windowWidth) { // 右邊緣出界 moveDiv.style.left = (windowWidth - moveDiv.clientWidth) + 'px'; // console.log('dx', windowWidth - moveDiv.clientWidth)}// 上下未出界if (this.yPum > 0 && (this.yPum + moveDiv.clientHeight < windowHeight)) { moveDiv.style.top = this.yPum +'px';} else if (this.yPum <= 0) { // 上邊緣出界 moveDiv.style.top = 0 + 'px'} else if (this.yPum + moveDiv.clientHeight >= windowHeight) { // 下邊緣 // console.log('windowHeight:', windowHeight) // console.log('moveDiv.clientHeight:', moveDiv.clientHeight) // console.log(this.yPum + moveDiv.clientHeight) moveDiv.style.top = windowHeight - moveDiv.clientHeight + 'px'}// 阻止頁面的滑動默認(rèn)事件,為了只讓懸浮球滑動,其他部分不滑動;如果碰到滑動問題,1.2 請注意是否獲取到 touchmove, 系統(tǒng)默認(rèn)passive: true,無法使用preventDefault// document.addEventListener('touchmove', function(){// event.preventDefault();// }, { passive: false });// document.addEventListener('mousemove', function(){// event.preventDefault();// }, { passive: false });document.addEventListener('touchmove', this.preventDefault, { passive: false })document.addEventListener('mousemove', this.preventDefault, { passive: false }) } }, //鼠標(biāo)釋放時候的函數(shù),鼠標(biāo)釋放,移除之前添加的偵聽事件,將passive設(shè)置為true,不然背景會滑動不了 end(){ this.flags = false // 注意事項(xiàng),在添加和刪除監(jiān)聽事件時,其function必須是同名的函數(shù),不能為匿名函數(shù)。 document.removeEventListener(’touchmove’,this.preventDefault, false) document.removeEventListener(’mousemove’,this.preventDefault, false) // 下面兩句是保證在移除監(jiān)聽事件后,除了懸浮球的部分還能夠滑動,如果不添加,則無法滑動 document.addEventListener('touchmove', function(e) {window.event.returnValue = true }) document.addEventListener('mousemove', function(e) {window.event.returnValue = true }) }, preventDefault(e) { e.preventDefault() } }, created() {}, mounted() {}}</script><style lang='scss' scoped>.xuanfu { /* 如果碰到滑動問題,1.3 請檢查 z-index。z-index需比web大一級*/ z-index: 999; position: fixed; // 這里的定位方式有待考量,fixed的話存在未知設(shè)置不合理,跑出屏幕不顯示的問題}</style>

到此這篇關(guān)于Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼的文章就介紹到這了,更多相關(guān)Vue 懸浮球內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品一区二区三区中文字幕| 欧美日韩日本国产亚洲在线| 石原莉奈一区二区三区在线观看| 91九色精品| 国产精品日韩久久久| 国产模特精品视频久久久久| 亚洲精品成人一区| 欧美黄页在线免费观看| 国产欧美一区二区三区精品观看| 日本久久一区| 里番精品3d一二三区| 四虎8848精品成人免费网站| 久久久久久自在自线| 99热精品在线| 日韩精品国产欧美| 精品国产鲁一鲁****| 精品国产美女a久久9999| 久久久久一区| 免费观看日韩电影| 麻豆精品在线视频| 国产中文一区| 日韩一区二区三区精品视频第3页| 国产乱码精品一区二区三区四区 | 成人日韩av| 久久婷婷亚洲| 日本在线不卡视频一二三区| 精品精品99| 国产亚洲精品自拍| 国产乱码精品一区二区三区四区 | 久久精品导航| 精品91久久久久| 日韩国产一区二| 日本а中文在线天堂| 久久亚洲国产精品一区二区| 麻豆精品少妇| 99视频一区| 蜜桃精品视频| 免费视频久久| 国产suv精品一区二区四区视频| 极品日韩av| 国产精品va| 亚洲电影在线一区二区三区| 国产视频网站一区二区三区| 成人看片网站| 国产日韩在线观看视频| 国产+成+人+亚洲欧洲在线| 中文日韩欧美| 国产不卡精品| 国产色99精品9i| 亚洲欧美视频| 午夜精品成人av| 国产精品一区三区在线观看| 欧美va天堂在线| 福利片在线一区二区| 日韩激情中文字幕| 91久久午夜| 欧美羞羞视频| 精品一区二区三区中文字幕 | 日韩欧美激情| 国产91精品对白在线播放| 国产精品sm| 亚洲男人在线| 蜜臀久久99精品久久一区二区| 国产欧美在线观看免费| 久久性天堂网| 视频小说一区二区| 久草精品视频| 国产精品视频3p| 日本va欧美va瓶| 亚洲视频二区| 免费日韩视频| 激情欧美亚洲| 日韩电影免费网站| 欧美日韩夜夜| 日韩在线观看中文字幕| 亚洲精品国产偷自在线观看| 国产999精品在线观看| 欧美私人啪啪vps| 中文字幕成人| 免费人成黄页网站在线一区二区| 91精品1区| 成人羞羞视频在线看网址| 久久精品国产网站| 国产精品久久久久77777丨| 91欧美极品| 日韩高清欧美激情| 爽好多水快深点欧美视频| 米奇777超碰欧美日韩亚洲| 人人精品亚洲| 久久蜜桃精品| 99久久精品费精品国产| 精品丝袜在线| 欧美成人基地 | 免费成人网www| 午夜国产一区二区| 免费观看不卡av| 99久久久久| 女人av一区| 国产美女一区| 午夜亚洲福利| 国产精品一线| 国产精品国产一区| 超碰99在线| 色综合www| 精品一区免费| 在线日韩成人| 国产亚洲一区| 国产成人精选| 婷婷成人综合| 蜜桃久久av一区| 亚洲综合小说| 五月亚洲婷婷 | 成人影视亚洲图片在线| 精品99在线| 日韩毛片视频| 91久久久精品国产| 激情国产在线| 桃色av一区二区| 亚洲午夜视频| 六月婷婷一区| 国产精品亚洲人成在99www| 久久久久久夜| 亚洲免费黄色| 日韩综合一区二区三区| 国产精品视频一区二区三区| 成人一二三区| 亚洲男女av一区二区| 日韩一区二区三区精品视频第3页 日韩一区二区三区免费视频 | 婷婷综合亚洲| 午夜在线精品| 欧美永久精品| 岛国av在线网站| 亚洲国产不卡| 日韩中文av| 国产精品亚洲一区二区三区在线观看| 野花国产精品入口| 欧美视频精品全部免费观看| 国内精品亚洲| 一本色道精品久久一区二区三区| 综合一区av| 成人在线免费观看网站| 欧美日韩国产一区精品一区| 日本在线不卡视频| 中文字幕在线免费观看视频| 午夜欧美精品| 日韩福利视频一区| 国产综合色区在线观看| 久久大逼视频| 国产精品99久久免费| 91国语精品自产拍| 国产精品嫩模av在线| 日韩精品欧美激情一区二区| 亚洲网址在线观看| 一区二区三区四区日本视频| 欧美一级专区| 亚洲一区资源| 国产欧美另类| 在线精品视频在线观看高清| 国产精品久久久久77777丨| 午夜日本精品| 国产精品一区二区免费福利视频 | 少妇精品久久久一区二区三区| 国产va在线视频| 日本在线成人| 亚洲国产日韩欧美在线| 欧美精品1区| 一区二区亚洲视频| 成人日韩精品| 免费一区二区三区在线视频| 日韩中文字幕1| 日韩欧美一区免费| 中文视频一区| 97精品中文字幕| 国产精品日本一区二区不卡视频| 久久国产精品毛片| 久久久噜噜噜| 福利欧美精品在线| 国产女人18毛片水真多18精品| 美女91精品| 不卡视频在线| 99久久婷婷| 日韩久久电影| 久久久久久夜| 麻豆高清免费国产一区| 国产伦一区二区三区| 日韩av一区二区三区四区| 欧美日韩国产一区二区三区不卡| sm久久捆绑调教精品一区| 久久久久黄色| 久久国产精品美女| 青青草精品视频| 日韩精品免费视频人成| 免费黄网站欧美| 久久亚洲电影| 亚洲男女自偷自拍| 日韩午夜在线| 亚洲国内精品| 久久久久中文| 久久国产亚洲精品| 欧美午夜精彩|