PC端js禁止浏览器缩放

在网上找了很多资料,多多少少都有一些问题,现在重新整理一下。

1.网上的资料大多都是按照windows的devicePixelRatio来判断是否缩放的,这个判断不是很准确,因为在mac下,默认的devicePixelRatio是为2的,所以需要根据不同的操作系统来判断缩放比例。

devicePixelRatio详细介绍参考张鑫旭老师的博客https://www.zhangxinxu.com/wordpress/2012/08/window-devicepixelratio/ ,有兴趣的可以去了解一下

2. 监听鼠标滚动的代码也有问题,事件无法监听到,这里也重新改了一下,在windows和mac下自测都是ok的。

 

下面直接贴代码:

<script>
      // 判断pc浏览器是否缩放,若返回100则为默认无缩放,如果大于100则是放大,否则缩小
      function detectZoom (){
        var ratio = 0,
          screen = window.screen,
          ua = navigator.userAgent.toLowerCase();

        if (window.devicePixelRatio !== undefined) {
          ratio = window.devicePixelRatio;
        }
        else if (~ua.indexOf('msie')) {
          if (screen.deviceXDPI && screen.logicalXDPI) {
            ratio = screen.deviceXDPI / screen.logical
在 Vue2 的 PC 项目中,如果用户手动调整浏览器缩放比例而页面元素大小并未随之变化,这可能是由于默认样式、CSS 弹性布局(如 `vh`、`vw` 单位)或者设置了固定的像素宽度导致的。Vue 本身并不能直接处理浏览器缩放事件,但你可以通过以下几种方式解决: 1. **响应式设计**:使用 CSS 媒体查询 (media queries) 或者 Vue 自带的响应式功能,比如 `<v-app>` 的 `min-height` 和 `flex-shrink` 属性,确保内容可以根据屏幕尺寸自动调整。 ```css /* 使用媒体查询 */ @media screen and (max-width: 1200px) { .your-component { width: 100%; flex-shrink: 0; } } /* 或者在 Vue 中动态设置组件的样式 */ this.$refs.yourComponent.style.width = '100%'; ``` 2. **百分比单位**:尽量避免使用 `px`,而是使用 `%` 或者 `rem` 这样的相对单位来设置元素的宽度和高度。 3. **引入 CSS 预处理器**:如 SCSS 或 Less,可以使用变量定义一个基础的字体大小,并根据缩放比例计算其他尺寸。 4. **使用 Vue 插件**:可以查找一些专门处理响应式布局的 Vue 插件,如 `vue-responsive`,它们可以帮助处理窗口大小和缩放改变时的布局更新。 5. **检查代码是否阻止了缩放**:有时候某些 JavaScript 库或自定义脚本可能会阻止浏览器的默认缩放行为。确保你的代码中没有这样的限制。 记得在开发过程中进行充分的测试,特别是在实际设备上模拟各种缩放情况,确保页面的布局适应性良好。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值