当前位置:首页 > 文章列表 > 文章 > 前端 > HTML禁用Ctrl+滚轮缩放功能的终极攻略

HTML禁用Ctrl+滚轮缩放功能的终极攻略

2025-04-12 12:31:26 0浏览 收藏

有志者,事竟成!如果你在学习文章,那么本文《在HTML中禁用Ctrl+滚轮的页面放大和缩小功能的终极攻略》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

如何在HTML中禁用Ctrl+滚轮的页面放大和缩小功能?

本文介绍如何在HTML页面中禁用Ctrl键结合鼠标滚轮的页面缩放功能。 一些开发者尝试使用resize事件,但效果不佳。 以下提供两种有效的解决方案:

方案一:原生JavaScript方法

此方法通过监听mousewheelkeydown事件,并阻止默认行为来实现。代码如下:

document.addEventListener('mousewheel', function(e) {
  e = e || window.event;
  if ((e.wheelDelta && e.ctrlKey) || e.detail) {
    e.preventDefault();
  }
}, { capture: false, passive: false });

document.addEventListener('keydown', function(event) {
  if ((event.ctrlKey || event.metaKey) &&
      (event.keyCode === 61 || event.keyCode === 107 ||
       event.keyCode === 173 || event.keyCode === 109 ||
       event.keyCode === 187 || event.keyCode === 189)) {
    event.preventDefault();
  }
}, false);

方案二:Vue.js方法

在Vue.js框架中,可以通过methodsmounted生命周期钩子来控制页面缩放比例。示例代码如下:

methods: {
  keepRatio() {
    let ratio = 0;
    const screen = window.screen;
    const ua = navigator.userAgent.toLowerCase();
    if (window.devicePixelRatio !== undefined) {
      ratio = window.devicePixelRatio;
    } else if (ua.indexOf('msie') > -1) {
      if (screen.deviceXDPI && screen.logicalXDPI) {
        ratio = screen.deviceXDPI / screen.logicalXDPI;
      }
    } else if (window.outerWidth && window.innerWidth) {
      ratio = window.outerWidth / window.innerWidth;
    }
    if (ratio) { ratio = Math.round(ratio * 100); }
    this.ratio = (ratio / 100).toFixed(2);
    document.body.style.zoom = 1 / this.ratio;
  }
},
mounted() {
  this.keepRatio();
  window.addEventListener('resize', this.keepRatio);
}

这两种方法都能有效地防止Ctrl+滚轮缩放页面,确保页面视图的一致性。 选择哪种方法取决于你的项目是否使用Vue.js框架。

以上就是《HTML禁用Ctrl+滚轮缩放功能的终极攻略》的详细内容,更多关于的资料请关注golang学习网公众号!

CSS子元素不影响父高度的独门秘技CSS子元素不影响父高度的独门秘技
上一篇
CSS子元素不影响父高度的独门秘技
Redis启动后访问问题排查及解决方案
下一篇
Redis启动后访问问题排查及解决方案
  • Leaflet弹窗管理:移出标记自动关闭技巧
    文章 · 前端   |  25分钟前  |  
    Leaflet弹窗管理:移出标记自动关闭技巧
    160浏览 收藏
  • CSS实现表单错误样式—如何设计验证状态
    文章 · 前端   |  43分钟前  |  
    CSS实现表单错误样式—如何设计验证状态
    295浏览 收藏
  • JavaScript数组push与pop使用教程
    文章 · 前端   |  56分钟前  |  
    JavaScript数组push与pop使用教程
    177浏览 收藏
  • Angular动态输入值未更新API的解决办法
    文章 · 前端   |  1小时前  |  
    Angular动态输入值未更新API的解决办法
    247浏览 收藏
  • JavaScript多条件筛选:AND/OR逻辑动态教程
    文章 · 前端   |  1小时前  |  
    JavaScript多条件筛选:AND/OR逻辑动态教程
    205浏览 收藏
  • JS创建并下载文件的方法
    文章 · 前端   |  1小时前  |  
    JS创建并下载文件的方法
    443浏览 收藏
  • 事件循环阶段解析与详解
    文章 · 前端   |  1小时前  |  
    事件循环阶段解析与详解
    394浏览 收藏
  • 查看更多
    课程推荐
    查看更多
    AI推荐
    查看更多
    相关文章
    微信登录更方便
    • 密码登录
    • 注册账号
    登录即同意 用户协议隐私政策
    返回登录
    • 重置密码