uniapp和vue如何获取屏幕或盒子内容的宽高

 更新时间:2024年02月23日 14:59:04   作者:聪明的墨菲特 (o.O)?  
在实际开发中我们会遇到不确定高度的情况,下面这篇文章主要给大家介绍了关于uniapp和vue如何获取屏幕或盒子内容的宽高,文中通过代码介绍的非常详细,需要的朋友可以参考下

获取到屏幕的宽度和高度,可以根据需要将这些值用于布局、样式或其他操作。

一、获取屏幕宽高

1.uniapp

使用uni.getSystemInfo()方法来获取系统信息,包括屏幕的宽度和高度。(注意:uni.getSystemInfo()方法是一个异步方法,因此你需要在success回调函数中处理获取到的屏幕尺寸数据。)

methods: {
  getScreenSize() {
    uni.getSystemInfo({
      success: (res) => {
        const screenWidth = res.windowWidth; // 屏幕宽度,单位为px
        const screenHeight = res.windowHeight; // 屏幕高度,单位为px
        console.log('屏幕宽度:', screenWidth);
        console.log('屏幕高度:', screenHeight);
      },
    });
  },
},

 在需要获取屏幕宽度和高度的地方,调用getScreenSize()方法即可。

mounted() {
  this.getScreenSize(); // 在组件或页面加载完成后调用获取屏幕尺寸的方法
},

2.vue

使用window.innerWidth和window.innerHeight获取屏幕的宽高:

const screenWidth = window.innerWidth; // 屏幕宽度
const screenHeight = window.innerHeight; // 屏幕高度

二、获取盒子内容宽高

1.uniap

使用uni.createSelectorQuery()方法来创建一个选择器查询对象,来获取盒子内容撑起的宽度和高度。(注意:uni.createSelectorQuery()方法是一个异步方法,因此你需要在boundingClientRect回调函数中处理获取到的盒子尺寸数据。)

methods: {
  getBoxSize() {
    uni.createSelectorQuery()
      .select('.box') // 选择你要获取尺寸的盒子元素,这里假设盒子元素的class为box
      .boundingClientRect((rect) => {
        const boxWidth = rect.width; // 盒子的宽度,单位为px
        const boxHeight = rect.height; // 盒子的高度,单位为px
        console.log('盒子宽度:', boxWidth);
        console.log('盒子高度:', boxHeight);
      })
      .exec();
  },
},

 在需要获取盒子宽度和高度的地方,调用getBoxSize()方法即可。

mounted() {
  this.getBoxSize(); // 在组件或页面加载完成后调用获取盒子尺寸的方法
},

2.vue

在Vue组件中,通过this.$refs访问ref属性,并使用$el获取盒子元素的宽高:

<div ref="box" class="box"></div>

const boxWidth = this.$refs.box.$el.offsetWidth; // 盒子宽度
const boxHeight = this.$refs.box.$el.offsetHeight; // 盒子高度

console.log(boxWidth,boxHeight);

总结 

到此这篇关于uniapp和vue如何获取屏幕或盒子内容宽高的文章就介绍到这了,更多相关uniapp和vue获取屏幕内容宽高内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue中使用Element UI的Table组件实现嵌套表格功能

    Vue中使用Element UI的Table组件实现嵌套表格功能

    这篇文章主要介绍了Vue中使用Element UI的Table组件实现嵌套表格功能,演示如何在Vue中使用Element UI的Table组件实现嵌套表格,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • Vue3内置组件Teleport使用方法详解

    Vue3内置组件Teleport使用方法详解

    这篇文章主要介绍了Vue3内置组件Teleport使用方法,Teleport是Vue 3.0 新增的一个内置组件,主要是为了解决一些特殊场景下模态对话框组件、组件的渲染,带着些许的了解一起走进下面文章的详细内容吧
    2021-10-10
  • vue中可以绑定多个事件吗

    vue中可以绑定多个事件吗

    这篇文章主要介绍了vue中可以绑定多个事件吗,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • 详解vue保存自动格式化换行

    详解vue保存自动格式化换行

    这篇文章主要为大家介绍了vue保存自动格式化换行,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • 深入了解vue-router原理并实现一个小demo

    深入了解vue-router原理并实现一个小demo

    这篇文章主要为大家详细介绍了vue-router原理并实现一个小demo,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • 一个基于vue3+ts+vite项目搭建初探

    一个基于vue3+ts+vite项目搭建初探

    当市面上主流的组件库不能满足我们业务需求的时候,那么我们就有必要开发一套属于自己团队的组件库,下面这篇文章主要给大家介绍了一个基于vue3+ts+vite项目搭建的相关资料,需要的朋友可以参考下
    2022-05-05
  • Vue.js中computed的基本使用方法

    Vue.js中computed的基本使用方法

    Vue.js中,computed属性根据依赖进行缓存,只有依赖改变时才重新计算,这样有效提高性能,computed属性是响应式的,可以自动更新,并且默认是只读的,它与methods的主要区别在于计算属性具有缓存性,而方法每次调用都会执行,使用computed可以使模板更加简洁,提高应用性能
    2024-09-09
  • Vue实现路由懒加载的多种方式总结

    Vue实现路由懒加载的多种方式总结

    当构建的项目比较大的时候,懒加载可以分割代码块,提高页面的初始加载效率解决白屏问题,下面是几种常见vue路由懒加载的方法,感兴趣的朋友跟随小编一起看看吧
    2023-11-11
  • Vue+ElementUI实现表单动态渲染、可视化配置的方法

    Vue+ElementUI实现表单动态渲染、可视化配置的方法

    这篇文章主要介绍了Vue+ElementUI实现表单动态渲染、可视化配置的方法,需要的朋友可以参考下
    2018-03-03
  • 详解Vue基于 Nuxt.js 实现服务端渲染(SSR)

    详解Vue基于 Nuxt.js 实现服务端渲染(SSR)

    直接使用 Vue 构建前端单页面应用,页面源码时只有简单的几行 html,这并不利于网站的 SEO,这时候就需要服务端渲染,本篇文章主要介绍了详解Vue基于 Nuxt.js 实现服务端渲染(SSR),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-04-04

最新评论