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

建立个人网站服务器如何用dedecms做网站

建立个人网站服务器,如何用dedecms做网站,西安网站维护招聘,网站续费一般多少钱目录 解决问题的思路#xff1a; 解决问题的方案#xff1a; 1、给roter-view添加key#xff08;破坏复用机制#xff0c;强制销毁重建#xff09; 2、使用beforeRouteUpdate导航钩子 3、使用watch监听路由 vue3路由缓存#xff1a;当用户从/users/johnny导航到/use…目录 解决问题的思路 解决问题的方案 1、给roter-view添加key破坏复用机制强制销毁重建 2、使用beforeRouteUpdate导航钩子 3、使用watch监听路由 vue3路由缓存当用户从/users/johnny导航到/users/jolyne时相同的组件实例被重复使用。由于两个路由都渲染相同的组件比起销毁再创建复用是比较高效的但是这也会导致组件的生命周期狗子不会被调用 根据小仙兔项目进行代码编辑。 解决问题的思路 1、让组件实例不复用强制销毁重建 2、监听路由变化变化之后执行数据更新 解决问题的方案 1、给roter-view添加key破坏复用机制强制销毁重建 当前路由完整路径为key的值给router-view组件绑定 方法一添加一个Key 破坏复用机制 强制销毁重建 太过粗暴 所有的都销毁重建 RouterView :key$route.fullPath / 2、使用beforeRouteUpdate导航钩子 onBeforeUpdate是生命周期钩子在组件的任何响应式依赖发生变化之前被调用。这不仅仅是针对路由的也包括其他的响应式数据。  onBeforeUpdate更为一般任何响应式数据的变化都会触发这个钩子。如果你使用它来监听路由变化你需要自己判断路由是否真的发生了变化 onBeforeUpdate因为它响应组件内任何数据的变化所以可能会在很多情况下被触发。但是只要你避免在这个钩子里执行计算密集或昂贵的操作性能影响应该是可以接受的 // 封装category相关的业务代码 import { getCategoryAPI } from /apis/category; import { onBeforeRouteUpdate, useRoute } from vue-router; import { ref, onMounted } from vue; export function useCategory() {// 获取数据const categoryData ref({});const route useRoute();const getCategory async (id route.params.id) {const res await getCategoryAPI(id);categoryData.value res.result;};onMounted(() {getCategory(route.params.id);});// 目标路由参数变化的时候可以把分类数据接口重新发送onBeforeRouteUpdate((to) {//console.log(to); //to代表目标路由对象// 存在问题使用最新的路由参数请求最新的分类数据getCategory(to.params.id);});return {categoryData,}; } 在index.vue中引入使用 import { useCategory } from /views/Category/composables/useCategory; const { categoryData } useCategory(); 3、使用watch监听路由 watch通常用于监听某个特定的响应式引用或响应式对象的变化并在这些变化时执行某些操作 watch更为专一只在所监听的响应式数据发生变化时执行。对于路由监听它允许你精确地知道什么时候路由发生了变化并提供了新旧值 watch由于它只响应特定的数据变化因此性能开销通常较小 在category中使用watch监听 // 封装category相关的业务代码 import { getCategoryAPI } from /apis/category; import { useRoute } from vue-router; import { ref, onMounted, watch } from vue; export function useCategory() {// 获取数据const categoryData ref({});const route useRoute();const getCategory async (id route.params.id) {const res await getCategoryAPI(id);categoryData.value res.result;};onMounted(() {getCategory(route.params.id);});watch(() route.params.id,(newValue, oldValue) {// console.log(route, newValue, oldValue);if (newValue route.path /category/${newValue}) {//需要保证在跳转到的路由是咱们的目标路由时才请求分类的数据getCategory(newValue);}},{ deep: true });return {categoryData,}; } 可根据场景需要使用这三种方法 1、如果你只关心路由的变化并且需要新旧值使用 watch 可能更合适 2、如果你希望在组件的任何数据变化之前执行某些操作无论是路由还是其他数据那么 onBeforeUpdate 更为适合 3、不在意性能问题选择key简单粗暴 如果只是为了监听路由变化watch 可能更为适合因为它提供了更精确的控制和明确的新旧值。而 onBeforeUpdate 更适用于在组件的任何数据变化之前执行操作的情况。不在意性能问题选择key简单粗暴 若有问题可以留言~ :)
http://www.zqtcl.cn/news/497273/

相关文章:

  • php网站开发实市场推广策略 包括哪些
  • 合众商道网站开发可以投稿的写作网站
  • 北京贸易公司网站制作免费的查企业的网站
  • 网站建设报价表模板下载小程序怎么找出来
  • 网站制作简单协议wordpress快速建站教程视频教程
  • 杭州做网站价格北京企业响应式网站建设
  • 30个成功的电子商务网站设计中企动力 网站报价
  • php 网站开发 视频百度seo排名查询
  • 网站开发代码wordpress提示安装
  • 网站推广的策略高端网球拍
  • 广东知名网站建设wordpress 用户量
  • asp源代码网站网络架构图是什么
  • 专业做淘宝网站公司吗苏州网站制作开发
  • 电商网站模板html安阳历史
  • seo快速排名多少钱安阳网站怎么优化
  • 如何在网站后台删除栏目阿里巴巴上做网站要多少钱
  • 网站建设意识形态工作河北省两学一做网站
  • 綦江建站哪家正规php做不了大型网站吗
  • 优秀的设计网站青岛网站设计企业
  • 谁有做爰网站号wordpress 4.8 中文
  • 毕业设计做网站用什么广州中智软件开发有限公司
  • 哪个网站不花钱可以做招聘wordpress没有页脚
  • 免费视频网站素材网络系统管理技能大赛
  • 聊天网站建设网站建设毕业设计评价
  • 网站建设 内容缺乏域名备案要多久
  • 产品展示型网站建设全国新冠疫苗接种率
  • 网站建设商如何自建商城和电商平台
  • 深圳做二类学分的网站开发一平方米多少钱
  • 如何做原创小说网站建一个o2o网站
  • 东莞市住房建设网站互动科技 网站建设