XingYun blog
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具

XingYun

冲!
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具
  • 3个提升Vue性能的写法
  • 重读Vue文档
  • moment.js给定时间获取自然月、周的时间轴
  • Vue虚拟dom与Diff算法
  • 深入响应式原理
  • Echart样例
  • 我的Vue指令库
  • 滚动到底部加载更多
  • 实现一键换肤
  • 手写Vue数据劫持
  • vue-router核心原理与手写实现
  • computed和watch
  • vue数组为什么不是响应式
  • v-for为什么不能用index做key
  • webpack loader和plugin
  • keep-alive组件原理
  • vue插槽进化
  • Vue多层嵌套组件
  • vue生命周期hook
    • vue监听dom元素的resize事件
    • 前端打包需要gzip压缩吗
    • 实现水波浪进度球
    • Vue
    XingYun
    2022-01-25
    目录

    vue生命周期hook

    vue 生命周期 hook 在实际开发时有什么用? 下面我列出几个例子

    # 一、Echart 监听图表容器的大小并改变图表大小

    在有些场景下,我们希望当 echart 容器大小改变时,图表的大小也相应地改变。

    比如,图表容器是一个高度为 400px、宽度为页面 100% 的节点,你希望在浏览器宽度改变的时候,始终保持图表宽度是页面的 100%。

    ![](https://gcy-1306312261.cos.ap-chengdu.myqcloud.com/blog/Jan-25-2022 16-13-00.gif)

    代码

    <template>
      <div ref="echarts"></div>
    </template>
    
    <script>
    
    mounted() {
      this.chart = echarts.init(this.$refs.echarts)
      // 监听窗口发生变化,echart图例自适应刷新
      window.addEventListener('resize', this.resize)
    }
    
    beforeDestroy() {
      window.removeEventListener('resize', this.resize)
      this.chart.dispose() // 销毁ehcart实例
    }
    
    methods: {
      resize() {
        this.chart && this.chart.resize()
      }
    }
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23

    这里利用了 destroyed 钩子 去销毁 dom resize 监听事件

    还有一种更简洁的写法

    <script>
    
    mounted() {
        this.chart = echarts.init(this.$refs.echarts)
        // 监听窗口发生变化,echart图例自适应刷新
        window.addEventListener('resize', this.resize)
        // beforeDestroy remove事件 销毁实例
        this.$once('hook:beforeDestroy', () => {
          window.removeEventListener('resize', this.resize)
          this.chart.dispose()
        })
      }
    
    methods: {
      resize() {
        this.chart && this.chart.resize()
      }
    }
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19

    这里 beforeDestroy 钩子执行时将触发 'hook:beforeDestroy' 事件

    我们可以根据具体业务用$on,$once 去监听所有的生命周期钩子函数。

    这里我的业务只需要执行一次,就用的$once。

    tips:如果你的业务里 window 的 resize 会高频触发,那么你可以考虑单独监听 dom 的 resize 事件

    # 二. 利用钩子函数销毁定时器

    场景:时间显示

    在这里插入图片描述

    在工作中遇到计时器相关的需求得格外小心

    打开某些网站,让这个tab在那放半小时后发现页面崩了,啥都点不动了,大概率和计时器任务一直频繁调用有关

    每定义一个计时器,就会在计时器线程的队列里面新加入一个排队的计时器。即使这个你跳转到另外一个页面,这个队列仍然存在。等计时器的一到,就会把这个计时器要执行的内容从队列拿出来开始执行。

    <template>
      <div v-text="currentTime"></div>
    </template>
    
    <script>
      data: function () {
        return {
        	currentTime: moment().format('HH: mm: ss')
        }
      }
    
      created() {
      	this.startTime()
      }
    
      methods:{
          startTime(){
            let timer = setInterval(()=>{
             this.currentTime = moment().format('HH: mm: ss')
            },1000);
            // hook优化写法清除定时器
            this.$once('hook:beforeDestroy',()=>{
              clearInterval(timer);
              timer = null;
            })
          }
       }
    </script>
    
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    #vue
    上次更新: 2023/04/05, 09:41:10
    Vue多层嵌套组件
    vue监听dom元素的resize事件

    ← Vue多层嵌套组件 vue监听dom元素的resize事件→

    最近更新
    01
    JavaScript-test
    07-20
    02
    二维码的原理
    07-20
    03
    利用ChatGPT优化代码
    07-20
    更多文章>
    Theme by Vdoing | Copyright © 2021-2023 XingYun | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式