<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="app1">
<!--组件关联,将msg展示在页面,最终展示值为msg,所以需要使用msg进行传值-->
父级:{{a}}
<br />
<child-com :msg="a">
<!--//:msg相当于v-model进行数据绑定 --> </child-com>
</div>
<template id="child">
<div>
<h2>我是子组件</h2>
<!--//在子组件中进行展示-->
<input type="button" value="按钮" @click="change"/>
<strong>{{msg}}</strong>
</div>
</template>
</body>
<script>
var app =new Vue({
el:"#app1",
data:{
a:'我是父组件的数据' },
/*//子组件,利用props进行数据传递:*/
components:{
'child-com':{
props:['msg'],
template:'#child',
methods:{
change(){
this.msg='被更换了'
}
}
}
}
})
</script>
</html>

在更改子组件数据的时候,是可以进行更改的,通过change方法进行更改:

展示结果:

点击change之后:

问题:子组件数据更改,怎么去更改父组件的数据呢:禁止通过props去更改数据

解决方案:

一:每次进行传值采用对象进行传值,对象之间是引用的,所以在更改之后是引用的

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="app1">
<!--组件关联,将msg展示在页面,最终展示值为msg,所以需要使用msg进行传值-->
父级:{{giveData.a}}
<br />
<child-com :msg="giveData">
<!--//:msg相当于v-model进行数据绑定 --> </child-com>
</div>
<template id="child">
<div>
<h2>我是子组件</h2>
<!--//在子组件中进行展示-->
<input type="button" value="按钮" @click="change"/>
<strong>{{msg.a}}</strong>
</div>
</template>
</body>
<script>
var app =new Vue({
el:"#app1",
data:{
giveData:{
a:'我是父组件的数据'
} },
/*//子组件,利用props进行数据传递:*/
components:{
'child-com':{
props:['msg'],
template:'#child',
methods:{
change(){
this.msg.a='被更换了'
}
}
}
}
})
</script>
</html>

展示效果:

更改之后数据:

如果不想报错:可以进行给改自己的数据,然后通过mounted函数,将更改的数据传递给自己.

如果想更改自己数据,不更改父组件的案例:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js"></script>
</head>
<body>
<div id="app1">
<!--组件关联,将msg展示在页面,最终展示值为msg,所以需要使用msg进行传值-->
父级:{{a}}
<br />
<child-com :msg="a">
<!--//:msg相当于v-model进行数据绑定 --> </child-com>
</div>
<template id="child">
<div>
<h2>我是子组件</h2>
<!--//在子组件中进行展示-->
<input type="button" value="按钮" @click="change"/>
<strong>{{b}}</strong>
</div>
</template>
</body>
<script>
var app =new Vue({
el:"#app1",
data:{ a:'我是父组件的数据' },
/*//子组件,利用props进行数据传递:*/
components:{
'child-com':{
data(){
return {
b:''
}
},
props:['msg'],
template:'#child',
mounted(){
this.b=this.msg;
},
methods:{
change(){
this.b='被更换了'
}
}
}
}
});
</script>
</html>

更改子组件数据,就是更改子组件的数据.

展示效果:

change之后:

最新文章

  1. Node.js——Async
  2. SPSS数据分析—卡方检验
  3. 神奇的main方法详解
  4. JavaScript设计模式 - 迭代器模式
  5. Dom实例:数据自增、搜索框及跑马灯
  6. rel=&quot;stylesheet&quot; 描述
  7. 讨论下IDS的绕过
  8. JSON序列化选项
  9. BZOJ 1029: [JSOI2007]建筑抢修
  10. 02、Unicode 汉子转码小工具
  11. java 获取URL链接 内容
  12. rocketmq双主模式
  13. JSON.stringify() 和 JSON.parse()
  14. javascript 中 x offsetX clientX screenX pageX的区别
  15. 剑指Offer 50. 数组中重复的数字 (数组)
  16. Selenium&#183;自动化基础
  17. Centos7下安装docker(1)
  18. fread和fseek的用法
  19. JQuery UI之Autocomplete(3)属性与事件
  20. php性能分析工具xhprof

热门文章

  1. 01-19asp.net网站--关于“应用程序中的服务器错误(需添加&quot;Jquery&quot;ScriptRescourseMapping)”
  2. S2SH整合所需jar包及其详解
  3. jumpserver跳板机的搭建
  4. python爬虫(1)--Urllib库的基本使用
  5. C++知识点总结(四)——面向对象的编程细节总结
  6. final 子类禁止重写
  7. linux时区修改为中国时区
  8. linux中怎么结果一页一页输出
  9. JavaPersistenceWithMyBatis3笔记-第4章SQL Mappers Using Annotations-001
  10. 删除匹配某个pattern的一组键