前端报错adding CSS “touch-action: none“ to this element解决方案

目录

如图所示控制台出现报错:

原因:

[touch-action 介绍:](#touch-action 介绍:)

解决方案:

1.手动设置touch-action:

2.使用条件渲染:

3.CSS样式隔离:

4.浏览器兼容性:

[5. 忽略警告](#5. 忽略警告)


如图所示控制台出现报错:

报错定位:本人在这个页面引入了一个组件,而那个组件是需要进行拖拽或者滑动之类的操作,在此之前没有出现报错的,应该就是这里的问题。

这应该与浏览器尝试优化滚动性能或触摸事件的处理有关,他报错的意思是需要我们再在css中添加一个css属性。

原因:

  1. 第三方库或框架 :有些第三方库(如滑动库、拖拽库等)可能会自动给元素添加touch-action: none;,以防止默认的滚动行为干扰其自定义的滑动或拖拽逻辑。

  2. 浏览器优化 :现代浏览器会尝试预测用户的意图,以提高页面的响应性和滚动性能。当浏览器检测到元素可能阻止默认滚动行为时,它可能会发出警告。

touch-action 介绍:

touch-action CSS属性是用来指定一个区域(例如一个按钮或整个页面)是否以及如何响应触摸事件(如滑动或缩放)的。

最常见的用法是禁用元素(及其不可滚动的后代)上的所有手势,以使用自己提供的拖放和缩放行为(如地图或游戏表面)。

css 复制代码
#map {
  touch-action: none;
}

另一种常见的模式是使用指针事件处理水平平移的图像轮播,但不想干扰网页的垂直滚动或缩放。

css 复制代码
.image-carousel {
  width: 100%;
  height: 150px;
  touch-action: pan-y pinch-zoom;
}

触摸动作 也经常用于完全解决由支持双击缩放手势引起的点击事件的延迟。

css 复制代码
html {
  touch-action: manipulation;
}

解决方案:

1.手动设置touch-action:

使用一个div盒子包裹你的组件,并在标签上添加 touch-action: none。

我是这样解决的,报错信息让你加你就加呗,添加行内也行,看自己啦

javascript 复制代码
<template>  
  <div class="my_component">  
    <!-- 组件内容 -->  
  </div>  
</template>
javascript 复制代码
.my_component {  
  touch-action: none; /* 只在需要的元素上设置 */  
}

2.使用条件渲染

如果touch-action: none;是在特定条件下需要的,考虑使用Vue的条件渲染(如v-if)来动态添加或移除这个样式。

javascript 复制代码
:style="`touch-action:${setTouch?'auto':'none'} ;`"

3.CSS样式隔离:

确保你的CSS样式不会意外地影响到不应该影响的元素。使用更具体的选择器来定位需要这个属性的元素。,同时在当前页面添加scoped,使当前页面的css样式独立

css 复制代码
<style scoped>

4.浏览器兼容性

浏览器是否支持touch-action属性。(见下图)

5. 忽略警告

如果这个警告不影响你的应用的功能或性能,你可以选择直接忽略它。然而,最好是解决潜在的问题,以确保应用的最佳性能和用户体验。

结束啦!

相关推荐
恋猫de小郭15 分钟前
再聊 Flutter Riverpod ,注解模式下的 Riverpod 有什么特别之处,还有发展方向
android·前端·flutter
Aress"17 分钟前
【2025前端高频面试题——系列一之MVC和MVVM】
前端·mvc
海绵老呆20 分钟前
纯html文件实现目录和文档关联
css·html·css3
Json____22 分钟前
好玩的谷歌浏览器插件-自定义谷歌浏览器光标皮肤插件-Chrome 的自定义光标
前端·chrome·谷歌插件·谷歌浏览器插件·光标皮肤·自定义光标
蜡笔小新星1 小时前
Flask项目框架
开发语言·前端·经验分享·后端·python·学习·flask
Fantasywt5 小时前
THREEJS 片元着色器实现更自然的呼吸灯效果
前端·javascript·着色器
IT、木易5 小时前
大白话JavaScript实现一个函数,将字符串中的每个单词首字母大写。
开发语言·前端·javascript·ecmascript
张拭心8 小时前
2024 总结,我的停滞与觉醒
android·前端
念九_ysl8 小时前
深入解析Vue3单文件组件:原理、场景与实战
前端·javascript·vue.js
Jenna的海糖8 小时前
vue3如何配置环境和打包
前端·javascript·vue.js