zoukankan      html  css  js  c++  java
  • vue element的meun菜单自适应屏幕宽度

    项目中header用的element的meun菜单,由于项目中header的布局,使用layout布局也没法实现屏幕的宽度变化 菜单的每个题目的间距适当缩小,就想到用监听屏幕宽度来让他们之间的间距大小变化

      <el-col :class="screenWidth <= 1350 ? screenWidth <= 1200? 'meunStyle menuItem':'meunStyle menuItems' : 'meunStyle'"></el-col>

    data(){
    return{     screenWidth: 1920    } }, mounted() {// header头部监听 let that = this window.addEventListener('resize', function() { return (() => { window.screenWidth = document.body.clientWidth that.screenWidth = window.screenWidth })() }) // 若屏幕宽度变化 就实时派发 this.$EventBus.$emit('screenWidth', { Width: that.screenWidth }) },
     watch: {
        screenWidth(val) {
          this.screenWidth = val
        }
      },
     

    开始是在mouted里监听 屏幕的宽度直接赋给screenWidth变量,但在html中classs名始终没变化,在监听的方法里打印,这个变量是实时变化的,后来在watch里打印这个变量也只有刷新页面的时候打印一次,后来想虽然屏幕宽度始终有打印,但他在mouted中 也只有刷新页面的时候会调用 就在网上搜了下,网上有一个解决办法 是要在watch里边加个延时器,不太明白为什么可以,但确实可以了,但我最后没有用 因为当屏幕有变化的时候 因为延时器的问题header导航总会闪烁,最终用了$emit,$on实时派发,接收值即可

    后来发现 存在有个问题,也就是当刷新页面的时候,这个屏幕宽度没有进行操作的时候是不会走addEventListener方法的,所以他会在data里直接取这个screenWidth变量的值去判断class类名,这样肯定不行,万一我打开的是控制台,此时的屏幕宽度不是最大宽,所以 在mouted里边先让他获取屏幕宽度直接赋值给screenWidth,这样就没有问题了,下边这个才是最完整的mouted

     mounted() {
        this.screenWidth = document.body.clientWidth //这样一刷新页面 依旧可以先获取获取此时的屏幕宽
        this.user = localStorage.getItem('username')
        // header头部监听
        let that = this
        window.addEventListener('resize', function() {
          return (() => {
            window.screenWidth = document.body.clientWidth
            that.screenWidth = window.screenWidth
          })()
        })
        // 若屏幕宽度变化 就实时派发
        this.$EventBus.$emit('screenWidth', {
          Width: that.screenWidth
        })
      },
  • 相关阅读:
    Android Broadcast
    Android 向服务器发送XML数据及调用webservice
    Android ViewPager相册横向移动
    Android 启动模式
    SQL Server忘记sa用户密码处理方案
    ArcGIS 10的色带重复问题
    隐藏TabControl中的TabPage
    ArcMap工具箱中的工具不全,工具带有“锁”图标问题
    ArcEngine开发——根据图层名称获取对应图层
    获取本地网络中可用的SQL Server实例信息
  • 原文地址:https://www.cnblogs.com/yanyanliu/p/12794058.html
Copyright © 2011-2022 走看看