resize事件是改变窗口大小时发生的事件,可以在窗口开启、最大化、最小化、窗口大小改变(如拖拉改变窗口大小、move语句改变窗口大小、改变width或height属性以改变窗口大小)时发生。
1.监听浏览器窗口变化,实时获取该窗口的宽度和高度
//封装getWindowInfo()方法const getWindowInfo = () => {const windowInfo = {width: window.innerWidth,hight: window.innerHeight}console.log(windowInfo);};
2.监听 resize 事件
//通过window监听window.addEventListener('resize', getWindowInfo);//缺点是会频繁触发这个事件,造成页面卡顿,优化的方法使用防抖或节流。
优化后的方法:
防抖debounce:在事件触发n秒后再执行,如果在n秒内又有新的触发,就重新计算
节流throttle:连续事件触发,在指定的时间内,不管触发几次,就只执行一次
//使用防抖 (setTimeout定时器)const getWindowInfo = () => {const windowInfo = {width: window.innerWidth,hight: window.innerHeight}};const debounce = (fn, delay) => {let timer;return function() {if (timer) {clearTimeout(timer);}timer = setTimeout(() => {fn();}, delay);}};//触发事件 触发时间(指定时间内执行事件)const cancalDebounce = debounce(getWindowInfo, 500);window.addEventListener('resize', cancalDebounce);
//vue3 使用生命周期销毁钩子onUnmounted(() => {console.log('onUnmounted','打印是否生效');//移除监听事件window.removeEventListener('resize', cancalDebounce);})
参考:https://blog.csdn.net/weixin_46409887/article/details/129028214
正在学习Go语言的PHP程序员。