• 【Vue】避免Vue组件中常见的props默认值陷阱


    1. 对象和数组默认值的共享问题

    当你将一个对象或数组作为props的默认值时,它们会在组件的所有实例之间共享。这意味着如果一个组件修改了这个默认值,其他组件也会受到影响,因为它们共享同一个引用。

    陷阱:

    props: {
      userInfo: {
        type: Object,
        default: {}
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    问题: 如果一个组件修改了userInfo对象,其他使用相同组件的实例也会受到影响。

    解决方法: 使用一个函数来返回一个新的对象,以确保每个组件都有自己独立的对象。

    props: {
      userInfo: {
        type: Object,
        default: function () {
          return {};
        }
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2. 非原始值的默认值类型问题

    Vueprops默认值类型需要是原始值,例如字符串、数字、布尔值等。如果尝试将非原始值作为默认值类型,Vue可能会引发警告。

    陷阱:

    props: {
      items: {
        type: Array,
        default: []  // 非原始值的默认值类型
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    问题: 默认值类型应为原始值,而不是引用类型。

    解决方法: 在组件内部创建一个函数或计算属性来返回非原始值的默认值。

    props: {
      items: {
        type: Array,
        default: function () {
          return [];
        }
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    3. 使用默认值时的响应性问题

    props的默认值只在组件实例创建时设置一次。如果后续更改了默认值,不会触发组件的重新渲染。这可能导致组件无法正确响应后续的更改。

    陷阱:

    props: {
      count: {
        type: Number,
        default: 0
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    问题: 如果后续更改了count的默认值,组件不会重新渲染。

    解决方法: 如果需要在默认值更改后重新渲染组件,请使用计算属性或观察者来监视props的变化。

    props: {
      count: {
        type: Number,
        default: 0
      }
    },
    computed: {
      updatedCount() {
        return this.count; // 使用计算属性
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    4. 默认值与验证类型不匹配问题

    如果默认值与验证类型不匹配,Vue将不会发出警告,但仍然可能导致意外行为。

    陷阱:

    props: {
      age: {
        type: Number,
        default: '25' // 默认值与验证类型不匹配
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    问题: 默认值与验证类型不匹配可能导致类型错误和不一致的数据。

    解决方法: 确保默认值的类型与验证类型匹配。

    props: {
      age: {
        type: Number,
        default: 25 // 默认值与验证类型匹配
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    (附源码)ssm人力资源管理系统 毕业设计 271621
    Crypto(5)2023xctf ezCrypto(待补)
    TML转义字符:xss攻击与HTML字符的转义和反转义
    卧兔操刀,头部游戏公司莉莉丝出海,红人营销仅10天数据翻一倍
    Docker Desktop使用宿主机Windows的配置文件持久化存储数据
    1. Pthreads专栏简介
    【宝塔面板建站】本地连接云服务器的数据库 以阿里云服务器为例子(保姆级图文)
    常见LLM使用的分词算法总结
    C语言第五章第1-2节用while语句实现循环学习导案
    备战2022.9.15数学建模
  • 原文地址:https://blog.csdn.net/qq_44632227/article/details/132995268