touchmove在 部分android uc上面的滑动透传问题

2 篇文章 0 订阅

先来看一组代码

class test extends React.Component {
    render() {
        return (
            <div style={{height: 300, backgroundColor: 'red'}}
                 onTouchStart={this.onTouchStart}
                 onTouchMove={this.onTouchMove}
                 onTouchEnd={this.onTouchEnd}>
            </div>
        )
    }
    onTouchStart = e => {
        e.preventDefault();
    }
    onTouchMove = e => {
        e.preventDefault();
    }
    onTouchEnd = e => {
        e.preventDefault();
    }
}

在红米 uc上面执行后,发现上下滑动,会唤起浏览器的滑动,如下拉刷新最为明显,在网上查找了下,很多处理方式太坑了,什么触发的时候把 html,body 样式调整为 height: 100%; position: relative; 或者是加多一个层级作为fiexd来遮挡……..等等,都不会处理成功,干脆上 ant-design-mobile中的 组件查看,发现效果在uc上面不会存在滑动透传问题,所以就查到git中,如下

import RCDatePicker from 'rmc-date-picker/lib/DatePicker';

调用了该库,那么顺便咯,反正git能找到,https://github.com/xshua06/rmc-picker/blob/master/lib/Picker.js

var component = this.refs.component;

component.addEventListener('touchstart', this.onTouchStart, false);
component.addEventListener('touchmove', this.onTouchMove, false);
component.addEventListener('touchend', this.onTouchEnd, false);

用这种方式处理,好,试一下,发现在uc上面成功执行,就解决了touchmove的透传

class test extends React.Component {
    refDiv = null
    componentDidMount() {
        const { refDiv } = this;
        refDiv.addEventListener('touchstart', this.onTouchStart, false);
        refDiv.addEventListener('touchmove', this.onTouchMove, false);
        refDiv.addEventListener('touchend', this.onTouchEnd, false);
    }
    componentWillUnmount() {
        const { refDiv } = this;
        refDiv.removeEventListener('touchstart', this.onTouchStart, false);
        refDiv.removeEventListener('touchmove', this.onTouchMove, false);
        refDiv.removeEventListener('touchend', this.onTouchEnd, false);
    }
    render() {
        return (
            <div style={{height: 300, backgroundColor: 'red'}}
                 ref={refDiv => this.refDiv = refDiv}>
            </div>
        )
    }
    onTouchStart = e => {
        e.preventDefault();
    }
    onTouchMove = e => {

    }
    onTouchEnd = e => {

    }
}
在JavaScript中,`touchend`, `touchstart`, 和 `touchmove` 这三个事件分别对应触摸屏幕的结束、开始和移动阶段,常用于实现滑动图片或手势操作。下面是一个简要的介绍: 1. `touchstart` (触摸开始):当用户手指接触屏幕并开始滑动时触发,此时你可以获取到触点的坐标(如位置、数量等)以及一些其他触控信息,通常用于初始化滑动状态。 ```javascript function handleTouchStart(e) { var touch = e.touches; startTouchPosition = touch.pageX; // ... 其他初始化操作 } ``` 2. `touchmove` (触摸移动):用户手指在屏幕上持续移动时触发,你可以根据上一次的`touchstart`位置来计算当前的滑动距离。 ```javascript function handleTouchMove(e) { var touch = e.touches; var currentTouchPosition = touch.pageX; var slideDistance = currentTouchPosition - startTouchPosition; // 更新图片位置 moveImage(slideDistance); } ``` 3. `touchend` (触摸结束):当用户抬起手指时触发,这时滑动已经完成,你可以在此时完成相关的动作,比如停止滑动效果,或者处理用户的交互选择。 ```javascript function handleTouchEnd(e) { // 结束滑动动画 stopSlide(); // 可能的后续操作,如图片缩放或切换等 } ``` 在实际应用中,这些事件通常需要在HTML元素上添加`touchstart`, `touchmove`, 和 `touchend` 事件监听器,并且在每个函数内部管理滑动状态和响应行为。记得在处理完事件后清除事件监听,以避免内存泄漏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值