ResizeObserver 和nextTick 的用途

ResizeObserver

简单说下 ResizeObserver 的用法

  1. new ResizeObserver(fn) 接受一个回调函数
  2. 回调函数默认是接受一个数组
  3. 数组第一项就是你传入的需要改变大小dom。
  4. 在回调函数内部改变大小。
  5. 观察者在vue需要 在合适时机打开关闭

例子

ts 复制代码
const observer = new ResizeObserver(entries => {
  for (let entry of entries) {
    console.log('entry:', entry); 
    // 减去导航栏捣鼓   减去卡片高度
    (entry.target as HTMLElement).style.height = (window.innerHeight - 55 - 290) + 'px';
  }
})

onMounted(() => {
  nextTick(() => {
    if (expanded.value.length) {
      observer.observe(domRef.value)
    }
  })
})

onUnmounted(() => {
  observer.disconnect()
})

ResizeObserver:再次大小观察者意思
用途 :用于 js操作大小样式 在dom渲染之后再次改变大小。

获取dom 大小的Api

ts 复制代码
window.innerHeight   视口的大小

获取slot传进来的dom

ts 复制代码
//html
  <div ref="slotContainer" class="slot-container">
        <slot></slot>
  </div>

//ts
// 使用template ref获取slot容器元素
const slotContainer = ref<HTMLElement>()
const getSlotContent = () => {
  return slotContainer.value?.firstElementChild as HTMLElement
}

//  firstElementChild 重点 ,不能把ref直接写到template 和slot上面

nextTick

这里也能发现 vue nextTick 的用途,但不太明显。

比如你要完成先将当前dom移到视口顶部,再在dom后面插入一个div ,这样一个需求。 涉及到一个函数两个ui调整,vue有搜集响应式,最后触发,如果没有nextTick 就会没有中间动画过程。 我们使用nextTick 就可以实现,先插入dom,再滚动到顶部。

ts 复制代码
// 处理点击事件
const handleClick = async () => {
  if (props.isActive) {
    emit('activate', null); // 关闭激活项
    placeholderHeight.value = 0;
    return;
  }

  emit('activate', props.id); // 激活当前项
  placeholderHeight.value = getDetailHeight();

  // 等待 DOM 更新完成
  await nextTick();

  // 滚动到顶部
  const itemEl = itemRef.value;
  if (itemEl) {
    itemEl.scrollIntoView({ behavior: 'smooth', block: 'start' });
  }
};
相关推荐
空中海11 分钟前
05 React架构设计、项目实践与专家清单
前端·react.js·前端框架
人生鹿呀41 分钟前
AI 情绪陪伴助手:从 0 到 1 的 PWA + 跨端应用实战
前端
人生鹿呀1 小时前
从零打造滑板文化社区平台:React 19 + Node.js + AI 微服务全栈实战
前端
网络工程小王1 小时前
【LCEL 链式调用详解】调用篇-2
java·服务器·前端·数据库·人工智能
swipe1 小时前
别把语音 Agent 当成“接两个 API”——用 NestJS 搭一套 ASR + LLM + 流式 TTS 的实时语音助手
前端·后端·llm
GISer_Jing2 小时前
AI Agent中游产业链全景拆解:智能体开发的核心生态与技术版图
前端·人工智能·后端
前端之虎陈随易2 小时前
2年没用Nodejs了,Bun很香
linux·前端·javascript·vue.js·typescript
Hooray2 小时前
用时7天,花费30元,我vibe coding这个网站
前端·agent·ai编程
小小高不懂写代码3 小时前
RAG--检索增强生成--原理及实战
前端·人工智能
空中海3 小时前
04 工程化、质量体系与 React 生态
前端·ubuntu·react.js