记录一下一些小知识

  • vue的双向绑定

Vue的双向绑定是Vue框架中的一个重要特性,它可以使数据在视图和数据模型之间进行同步更新。在Vue中,使用v-model指令可以实现双向绑定,它可以将表单输入和组件状态绑定在一起,从而实现数据的双向同步。

例如,你可以在一个文本框中输入数据,然后使用v-model指令将该文本框与Vue实例中的数据属性进行绑定,这样当你修改文本框中的内容时,Vue实例中的数据属性也会相应地更新,反之亦然。

需要注意的是,v-model指令只能在表单元素和组件上使用,而不能用于普通的HTML元素。此外,双向绑定只是Vue框架中的一个特性,它并不是JavaScript语言本身的特性。       

  • js基本数据类型和引用数据类型的区别           

JavaScript中的数据类型可以分为基本数据类型和引用数据类型。

基本数据类型有:string、number、boolean、null、undefined、symbol。

引用数据类型有:object、array、function等。

它们之间的区别在于基本数据类型存储在栈内存中,而引用数据类型存储在堆内存中。具体来说,当我们声明一个基本数据类型的变量时,系统会在栈内存中开辟一段空间来存储该变量的值;而当我们声明一个引用数据类型的变量时,系统会在栈内存中开辟一段空间来存储该变量的引用,实际的数据则存储在堆内存中。

由于基本数据类型存储在栈内存中,因此它们的比较是值的比较。例如,当我们比较两个字符串变量时,系统会比较它们的值是否相等。而引用数据类型的比较则是引用的比较。例如,当我们比较两个对象变量时,系统会比较它们的引用是否相等,而不是它们的属性是否相等。

另外,由于引用数据类型的变量存储的是对象的引用,因此对该变量进行操作时,实际上是对该对象进行操作。例如,当我们修改一个对象变量的属性时,实际上是修改了该对象的属性,而不是变量本身的值。

需要注意的是,当我们将一个引用数据类型的变量赋值给另一个变量时,实际上是将该变量的引用复制给另一个变量,而不是复制该变量所引用的对象。因此,当我们修改其中一个变量所引用的对象时,另一个变量也会受到影响。这种情况被称为“浅拷贝”。如果想实现“深拷贝”,需要使用特殊的方法进行对象的复制。

  • 深拷贝的两种方法
const obj = { a: 1, b: { c: 2 } };
const newObj = JSON.parse(JSON.stringify(obj));
function deepClone(obj) {
  if (obj === null || typeof obj !== "object") {
    return obj;
  }
  
  const newObj = Array.isArray(obj) ? [] : {};
  
  for (let key in obj) {
    if (obj.hasOwnProperty(key)) {
      newObj[key] = deepClone(obj[key]);
    }
  }
  
  return newObj;
}

const obj = { a: 1, b: { c: 2 } };
const newObj = deepClone(obj);

  • vue父子传值 子组件改变父组件传来的值

在Vue中,父子组件之间的通信可以通过props和emit来实现。当子组件改变父组件传来的值时,父组件的值也会跟着改变。这是因为Vue中的数据是双向绑定的,即当一个组件的数据发生改变时,它会自动更新到父组件中。

假设父组件传递了一个属性prop到子组件中,并在子组件中修改了该属性的值。在这种情况下,如果使用了Vue的双向数据绑定,父组件的值也会随着子组件的改变而改变。具体来说,如果在子组件中使用v-model指令绑定prop,那么当子组件修改v-model绑定的值时,父组件的值也会跟着改变。

但是,在某些情况下,父组件的值可能不会随着子组件的改变而改变。比如,如果在子组件中使用了一个局部变量来存储prop的值,并在子组件中修改了局部变量的值,那么父组件的值不会受到影响。

总之,当子组件改变父组件传来的prop值时,父组件的值通常会跟着改变,但也要注意具体实现方式和使用情况。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值