期权记-ETF期权开户导航 期权记是专业的50ETF300ETF期权开户投资交易导航

Vue修改prop数据

  修改prop中的数据,通常有以下两种原因

  1、prop 作为初始值传入后,子组件想把它当作局部数据来用

  2、prop 作为初始值传入,由子组件处理成其它数据输出

  [注意]JS中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态

  对于这两种情况,正确的应对方式是

  1、定义一个局部变量,并用 prop 的值初始化它

props: ['initialCounter'],

data: function () {

  return { counter: this.initialCounter }

}

  但是,定义的局部变量counter只能接受initialCounter的初始值,当父组件要传递的值发生变化时,counter无法接收到最新值

<!DOCTYPE html>  <html>  	<head>  		<meta charset="UTF-8">  		<title></title>  	</head>  	<body>  		<div id="example">    <parent></parent>  </div>  <script src="https://unpkg.com/vue"></script>  <script>  var childNode = {    template: `    <div class="child">      <div>        <span>子组件数据</span>        <input v-model="temp">      </div>      <p>{{temp}}</p>    </div>    `,    props:['childMsg'],    data(){      return{        temp:this.childMsg      }    },  };  var parentNode = {    template: `    <div class="parent">      <div>        <span>父组件数据</span>        <input v-model="msg">      </div>      <p>{{msg}}</p>      <child :child-msg="msg"></child>    </div>    `,    components: {      'child': childNode    },    data(){      return {        'msg':'match'      }    }  };  // 创建根实例  new Vue({    el: '#example',    components: {      'parent': parentNode    }  })  </script>  	</body>  </html>

下面示例中,除初始值外,父组件的值无法更新到子组件中

2、定义一个计算属性,处理 prop 的值并返回

props: ['size'],

computed: {

  normalizedSize: function () {

    return this.size.trim().toLowerCase()

  }

}

但是,由于是计算属性,则只能显示值,而不能设置值

<!DOCTYPE html>  <html>  	<head>  		<meta charset="UTF-8">  		<title></title>  	</head>  	<body>  		<div id="example">    <parent></parent>  </div>  <script src="https://unpkg.com/vue"></script>  <script>  var childNode = {    template: `    <div class="child">      <div>        <span>子组件数据</span>        <input v-model="temp">      </div>      <p>{{temp}}</p>    </div>    `,    props:['childMsg'],    computed:{        temp(){          return this.childMsg        }    },  };  var parentNode = {    template: `    <div class="parent">      <div>        <span>父组件数据</span>        <input v-model="msg">      </div>      <p>{{msg}}</p>      <child :child-msg="msg"></child>    </div>    `,    components: {      'child': childNode    },    data(){      return {        'msg':'match'      }    }  };  // 创建根实例  new Vue({    el: '#example',    components: {      'parent': parentNode    }  })  </script>  	</body>  </html>

下面示例中,由于子组件使用的是计算属性,所以,子组件的数据无法手动修改

3、更加妥帖的方案是,使用变量储存prop的初始值,并使用watch来观察prop的值的变化。发生变化时,更新变量的值

<!DOCTYPE html>  <html>  	<head>  		<meta charset="UTF-8">  		<title></title>  	</head>  	<body>  		<div id="example">    <parent></parent>  </div>  <script src="https://unpkg.com/vue"></script>  <script>  var childNode = {    template: `    <div class="child">      <div>        <span>子组件数据</span>        <input v-model="temp">      </div>      <p>{{temp}}</p>    </div>    `,    props:['childMsg'],    data(){      return{        temp:this.childMsg      }    },    watch:{      childMsg(){        this.temp = this.childMsg      }    }  };  var parentNode = {    template: `    <div class="parent">      <div>        <span>父组件数据</span>        <input v-model="msg">      </div>      <p>{{msg}}</p>      <child :child-msg="msg"></child>    </div>    `,    components: {      'child': childNode    },    data(){      return {        'msg':'match'      }    }  };  // 创建根实例  new Vue({    el: '#example',    components: {      'parent': parentNode    }  })  </script>  	</body>  </html>

本站声明:网站内容来源于网络,如有侵权,请联系我们https://www.qiquanji.com,我们将及时处理。

微信扫码关注

更新实时通知

作者:期权小韭菜 分类:网页教程 浏览:
请先 登录 再评论,若不是会员请先 注册