iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript实现移动端禁止下拉露出网址广告屏蔽技巧
  • 807
分享到

JavaScript实现移动端禁止下拉露出网址广告屏蔽技巧

2024-04-02 19:04:59 807人浏览 八月长安
摘要

目录需求查找解决方案需求 移动端禁止下拉 露出网址或广告 查找解决方案 基本都是 document.body.addEventListener('touchmove', functi

需求

移动端禁止下拉 露出网址或广告

查找解决方案

基本都是

document.body.addEventListener('touchmove', function (e) { e.preventDefault() }, { passive: false })

就很离谱,这样会导致scroll无法滚动。

我的解决方案

function stopDown(el) {
    let startX, startY;
    // el是最外层div 
    el.addEventListener("touchstart", (e) => {
        startX = e.changedTouches[0].pageX;
        startY = e.changedTouches[0].pageY;
    })
    el.addEventListener("touchmove", (e) => {
        //获取滑动屏幕时的X,Y
        let endX = e.changedTouches[0].pageX;
        let endY = e.changedTouches[0].pageY;
        //获取滑动距离
        let distanceX = endX - startX;
        let distanceY = endY - startY;
        //判断滑动方向
        if (Math.abs(distanceX) > Math.abs(distanceY) && distanceX > 0) {
            // console.log('往右滑动');
        } else if (Math.abs(distanceX) > Math.abs(distanceY) && distanceX < 0) {
            // console.log('往左滑动');
        } else if (Math.abs(distanceX) < Math.abs(distanceY) && distanceY < 0) {
            // console.log('往上滑动');
        } else if (Math.abs(distanceX) < Math.abs(distanceY) && distanceY > 0) {
            // 核心在这  
            // path 是从触摸点到最外层所有祖先节点的集合,不了解就log看下
            let path = e.path
            let is_scrollTop = false
            // 从触摸点到最外层所有祖先节点 scrollTop不为0就不禁止下拉 为0 就禁止下拉
            for (let dom of path) {
                if (dom.scrollTop) {
                    is_scrollTop = true
                }
            }
            if (!is_scrollTop) {
                e.preventDefault()
                return false
            }
            // console.log('往下滑动');
        } else {
            // console.log('点击未滑动');
        }
    })
}

目前自测安卓 微信内、uc、小米浏览器 效果都不错,更多关于移动端禁止下拉广告网址的相关技巧请关注编程网其它相关文章!

--结束END--

本文标题: JavaScript实现移动端禁止下拉露出网址广告屏蔽技巧

本文链接: https://www.lsjlt.com/news/150390.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript实现移动端禁止下拉露出网址广告屏蔽技巧
    目录需求查找解决方案需求 移动端禁止下拉 露出网址或广告 查找解决方案 基本都是 document.body.addEventListener('touchmove', functi...
    99+
    2024-04-02
  • JavaScript如何实现移动端禁止下拉露出网址广告
    这篇文章主要介绍“JavaScript如何实现移动端禁止下拉露出网址广告”,在日常操作中,相信很多人在JavaScript如何实现移动端禁止下拉露出网址广告问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Jav...
    99+
    2023-06-30
  • HTML5如何实现手指下滑弹出负一屏阻止移动端浏览器内置下拉刷新功能
    小编给大家分享一下HTML5如何实现手指下滑弹出负一屏阻止移动端浏览器内置下拉刷新功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!H5手指下滑弹出负一屏, 阻止...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作