需求:vue项目移动端,用户需要对某个盒子双指缩放还可以滑动来查看内容

方法一:纯手写双指事件

1.HTML

		<div class="box">
      <div class="demo"  style="width: 700px;height: 400px;">
        <img class="img" src="https://img2.baidu.com/it/u=862159221,1723036925&fm=253&fmt=auto&app=138&f=JPEG?w=889&h=500">
      </div>
    </div>

2.js

缩放可以用css中的transform:scale 和 zoom

最后选择了zoom,用transform对盒子缩放后,滚动条有问题,滑动不到顶部去,有部分内容查看不了,滑动不了

<script>
export default {
  name: 'HelloWorld',
  props: {
    msg: String
  },
  data() {
    return {
			zoom:1
    }
  },
  methods:{

  },
  mounted(){
        const content = document.querySelector('.demo'); //获取需要放大缩小的盒子
        let firstDistance = 0; // 存放手指开始放上的时,两根手指之间的距离
        // 缩放事件的处理
        const getDistance =  (start, stop) => { //计算两根手指之间的距离
            return Math.sqrt(Math.pow(Math.abs(start.x - stop.x), 2) + Math.pow(Math.abs(start.y - stop.y), 2));
        };
        content.addEventListener('touchstart', function (event) { // 获取第一次触摸的点
            const touches = event.touches;
            if(touches.length > 1){ //判断是否是两指
                const events1 = touches[0];
                const events2 = touches[1];
                const one = {
                    x:events1.pageX, //第一根手指的横坐标
                    y:events1.pageY, //第一根手指的横坐标
                }; //第一根手指的横坐标
                const two = {
                    x:events2.pageX, //第二根手指的横坐标
                    y:events2.pageY, //第二根手指的横坐标
                }; 
                firstDistance = getDistance(one,two);
            }
            // event.preventDefault();
        });
        document.addEventListener('touchmove', (event) => {
            // event.preventDefault();
            const touches = event.touches;
            if(touches.length>1){
                const events1 = touches[0];
                const events2 = touches[1];
                const one = {
                    x:events1.pageX, //第一根手指的横坐标
                    y:events1.pageY, //第一根手指的横坐标
                }; //第一根手指的横坐标
                const two = {
                    x:events2.pageX, //第二根手指的横坐标
                    y:events2.pageY, //第二根手指的横坐标
                }; 
                const distance = getDistance(one,two);
                let zoom = distance / firstDistance
                // content.style.transform = 'scale('+ zoom +')';
                content.style.zoom = this.zoom  * zoom 
				//设置最大最小zomm
            }
        });
				document.addEventListener('touchend', (event)  => {
					this.zoom = content.style.zoom
				})
  }
}
</script>

方法二:插件Easyscroller

git地址:https://github.com/ulesta/easyscroller

npm地址:https://www.npmjs.com/package/easyscroller

使用方法

安装:npm i easyscroller --save

import { EasyScroller } from 'easyscroller'
mounted() {
 const ele = document.querySelector('#zoomBox'); //缩放盒子

  this.scroller = new EasyScroller(ele, {
    scrollingX: true,
    scrollingY: true,
    zooming: true,
    minZoom: 0.5,    //最小缩放
    maxZoom: 5,    //最大缩放
    zoomLevel: 0.5, //初始值缩放
    bouncing: false,
  });
},
beforeDestroy() {
  this.scroller.destroy(); //销毁
},

Logo

前往低代码交流专区

更多推荐