当前位置: 首页 > news >正文

企业网站源码 可去版权给网站网站做优化

企业网站源码 可去版权,给网站网站做优化,青岛工程建设管理信息网站下载,wordpress页面还原前言 Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。简单来说,Vue在修改数据后,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新&#xff…

前言

Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。简单来说,Vue在修改数据后,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新,nextTick()方法就会在这样的DOM更新循环结束后调用指定的函数。

概念

在 Vue 3 中 nextTick() 方法的行为和 Vue 2 中基本相似,但它进行了一些优化,以提高性能和稳定性。nextTick() 通过利用微任务(microtask)来确保在 DOM 更新之后执行回调,从而避免在同一事件循环中执行 DOM 操作。简单的理解是,当数据更新了,在dom中渲染后,自动执行函数。

方法的使用

nextTick()的基本使用

// 使用 nextTick() 方法
import { ref, nextTick } from 'vue';const myValue = ref('initial value');// 在 DOM 更新后执行回调
nextTick(() => {console.log('DOM 已更新');
});

再onMounted中使用

在该示例中,nextTick() 写onMounted 钩子函数中能确保回调在组件首次挂载后执行,常用于处理与初始渲染相关的逻辑。

// 示例 2: 在 setup() 中使用 nextTick()
import { ref, onMounted, nextTick } from 'vue';export default {setup() {const myValue = ref('initial value');onMounted(() => {// 在 DOM 更新后执行回调nextTick(() => {console.log('DOM 已更新');});});return {myValue,};},
};

nextTick() 的异步执行

nextTick() 中的回调函数是异步执行的。这意味着即使在同一事件循环中调用多次 nextTick(),它们的回调函数也会按照调用顺序异步执行。

// 示例 3: nextTick() 的异步执行
import { ref, nextTick } from 'vue';const myValue = ref('initial value');// 在 DOM 更新后执行第一个回调
nextTick(() => {console.log('第一个回调执行');
});// 在 DOM 更新后执行第二个回调
nextTick(() => {console.log('第二个回调执行');
});

nextTick() 的使用场景

在数据变化后等待DOM更新

这是 nextTick() 最常见的用途。例如,你可能更改了一个数据属性,该属性控制一个元素的可见性。然后你可能想要等待DOM更新以便可以获取该元素的新的宽度或高度。在这种情况下,你可以使用 nextTick() 来确保你的代码在DOM更新后执行。

<template>  <div ref="myDiv">{{ message }}</div>  
</template>  <script>  
import { ref, nextTick } from 'vue';  export default {  setup() {  const message = ref('Hello Vue!');  const myDiv = ref(null);  function updateMessage() {  message.value = 'Updated!';  nextTick(() => {  console.log(myDiv.value.textContent); // 输出: Updated!  });  }  return {  message,  myDiv,  updateMessage  };  }  
};  
</script>

在创建或销毁组件后等待DOM更新

当创建或销毁Vue组件时,Vue需要时间来更新DOM。如果你需要立即访问新创建或已销毁的DOM元素,你可能会遇到问题,因为DOM可能还没有更新。在这种情况下,你可以使用 nextTick() 来确保你的代码在DOM更新后执行。

<template>  <div>  <button @click="toggleComponent">Toggle Component</button>  <ChildComponent v-if="showChild" ref="childComponentRef" />  </div>  
</template>  <script>  
import { ref, nextTick } from 'vue';  
import ChildComponent from './ChildComponent.vue';  export default {  components: {  ChildComponent  },  setup() {  const showChild = ref(false);  const childComponentRef = ref(null);  
// 在这个例子中,我们有一个ChildComponent,它根据showChild的值来条件性地渲染。
//当我们点击按钮时,toggleComponent方法会被调用,它切换showChild的值。
//然后,我们使用nextTick()来等待Vue的DOM更新队列清空,确保如果ChildComponent被创建,
//它现在已经被挂载到DOM上;如果它被销毁,它已经从DOM上移除。async function toggleComponent() {  showChild.value = !showChild.value;  // 等待DOM更新  await nextTick();  if (showChild.value) {  // 现在ChildComponent已经被创建并挂载到DOM上  console.log('Child component has been mounted:', childComponentRef.value);  } else {  // 现在ChildComponent已经被销毁并从DOM上移除  console.log('Child component has been unmounted.');  }  }  return {  showChild,  childComponentRef,  toggleComponent  };  }  
};  
</script>

在异步更新队列中插入自己的回调

Vue 在更新 DOM 时是异步执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据,对于避免不必要的计算和 DOM 操作是非常重要的。然后,在下一个的事件循环“tick”中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部对异步队列尝试使用原生的 Promise.then、MutationObserver 和 setImmediate,如果执行环境不支持,则会采用setTimeout(fn, 0) 代替。你可以通过 nextTick() 将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。

处理大量数据

在处理大量数据时,Vue.js 可能会变得有点慢,因为它需要时间来处理所有的数据并更新DOM。在这种情况下,你可能想要使用 nextTick() 来分批处理数据,以便给浏览器一些时间来更新DOM。这可以提高应用程序的性能,并减少用户在处理大量数据时的等待时间。

<template>  <div>  <div v-for="(item, index) in items" :key="index">{{ item }}</div>  </div>  
</template>  <script>  
import { ref, nextTick } from 'vue';  export default {  setup() {  const items = ref([]);  function fetchData() {  // 假设 fetchDataFromAPI 是一个异步函数,用于从 API 获取数据  fetchDataFromAPI().then(newItems => {  items.value = newItems;  nextTick(() => {  console.log('All items are rendered');  // 这里可以执行依赖于所有项都已渲染的代码  });  });  }  return {  items,  fetchData  };  }  
};  
</script>

与第三方库集成

有些第三方库可能需要直接操作DOM,或者需要在DOM更新后才能正确工作。在这种情况下,你可以使用 nextTick() 来确保在集成这些库时DOM已经更新。例如,你可能想要在使用一个JavaScript动画库之前等待DOM更新,以确保动画在正确的元素上运行。或者你可能想要在使用一个需要测量元素尺寸或位置的库之前等待DOM更新。在这些情况下, nextTick() 可以帮助你确保DOM已经更新并准备好与第三方库集成。

<template>  <div ref="myDiv">Some Content</div>  
</template>  <script>  
import { ref, onMounted, nextTick } from 'vue';  
import someLibrary from 'some-library';  export default {  setup() {  const myDiv = ref(null);  onMounted(() => {  nextTick(() => {  // 确保 DOM 已经更新  someLibrary.doSomethingWithElement(myDiv.value);  });  });  return {  myDiv  };  }  
};  
</script>

http://www.yayakq.cn/news/431632/

相关文章:

  • 电脑怎么创建网站高邮网站建设
  • 网站建设图片路径错了 怎么改北京设计机构
  • 手机端网站制作因脉网站建设公司怎么呀韩国
  • 公司网站免费建站怎么样软件开发后端
  • 天空在线网站建设在线观看网站深夜免费
  • 从化五屏网站建设商标名字大全
  • 网站建设技术文案天津网站建设设计
  • 企业怎样做网站网站制作的公司
  • 网站用户体验比较厦门双瑞高磁网站是谁做的
  • 世界十大网站排名宁海县建设局网站下属单位
  • 信丰县建设局网站wordpress添加路由
  • 网站上做地图手机上显示女装网站建设规划书
  • 南通通州住房和城乡建设网站徐州网站建设 和信
  • 沈阳网 沈阳网站wordpress 强大
  • 做图表的网站知乎交友免费网站建设
  • 如何做网站资讯设计在线官网作品欣赏
  • 模板网站建设开发投资公司注册条件和要求
  • 精品课程网站开发环境wordpress外贸模板下载
  • 织梦响应式网站模板Wordpress变装
  • 常州网站建设技术托管ps教程网站有哪些
  • 北京路口优化北京网站设计制作关键词优化微信小程序开发推广
  • 想学网站开发wordpress 文章代码
  • 网站服务器崩溃怎么办wordpress自带api
  • 最适合新闻资讯建站的cms网站建设技术的发展
  • 关于12380网站建设文件智能网站建设报价
  • 静态页面网站在线图片编辑器手机版
  • 一个空间只能放一个网站吗怎么给钓鱼网站做防红
  • 保定电子网站建设专业的企业网站建设公司
  • 上海微网站制作建设wordpress主题无法安装
  • 网站建设-设计高德地图国际版