zoukankan      html  css  js  c++  java
  • vue 监听窗口变化对页面部分元素重新渲染

    问题

    在处理页面重新渲染时通常的做法是:

    1. 用vue-router重新路由到当前页面,页面是不进行刷新的
    2. 采用window.reload(),或者router.go(0)刷新时,整个浏览器进行了重新加载,闪烁,体验不好

    使用 v-if 重新渲染部分组件或容器

    需要重新渲染的内容

    <div v-if="render">
      ...
    </div>
    

    vue 监听窗口大小发生改变

    使用 window.addEventListener() 添加 resize 事件监听窗口变化

    new Vue({
      el: '#app',
      data() {
        return { render: true }
      },
      mounted() {
        window.addEventListener('resize', this.reload)
      },
      beforeDestroy() {
        window.removeEventListener('resize', this.reload)
      },
      methods: {
        reload() {
          // 重新渲染
          this.render = false
          this.$nextTick(() => {
            this.render = true
          })
        }
      }
    })
    
    完结~
  • 相关阅读:
    BASIC-2 01字串
    BASIC-1 闰年判断
    BASIC-11 十六进制转十进制
    IO流之File类
    集合-下
    集合-上
    java常用类-下
    关于String的一些基础小题目
    java常用类-上
    异常
  • 原文地址:https://www.cnblogs.com/lwlblog/p/13371770.html
Copyright © 2011-2022 走看看