V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Artiver
V2EX  ›  Vue.js

请教 Vue3 的 defineComponent 函数使用

  •  
  •   Artiver · 7 小时 29 分钟前 · 176 次点击

    各位好,我又来请教个 Vue3 的问题,标签页系统使用 defineComponent 创建组件,实现刷新功能。由于组件需要缓存,使用了 keepalive ,于是用 pinia 存储组件的 name 属性,所以创建时在 name 加上时间戳将其表示唯一。

    GitHub 地址

    createNode.js的部分代码片段如下,本意是想看下创建组件时的时间戳:

    function getTimeStamp() {
      let timeNow = Date.now();
      console.log("create: ", timeNow);
      return timeNow;
    }
    
    export function createNameComponent(component) {
      return () => {
        return new Promise((resolve) => {
          component().then((comm) => {
            const tempComm = defineComponent({
              name: (comm.default.name || "vueAdminBox") + "_" + getTimeStamp(),
              props: comm.default.props || {},
              ...
    

    当前实现效果如下:

    20240919 223831

    可以看到,组件只有第一次打开时会触发getTimeStamp函数,关闭再打开就不会重新获取时间戳了。

    我期望每次打开标签页都是不同的时间戳,有老哥遇到这个问题吗?

    1 条回复    2024-09-20 02:40:58 +08:00
    shakukansp
        1
    shakukansp  
       3 小时 48 分钟前
    稍微看了看,你这 router 的 modules 里面每个路由的 component 只调了一次啊

    你要重复调用 createNameComponent ,得用 addRoute 和 remove route 修改记录
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1007 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 87ms · UTC 22:29 · PVG 06:29 · LAX 15:29 · JFK 18:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.