vue 组件数据传递
//比如<ppx v-bind:data="arr"></ppx>
//简写<ppx :data="arr">
子组件通过props来接收数据
//props:['data']
最后使用即可
//{{data}}
注意:
自定义属性不要和子组件数据名称一样
<div id="app">
<!-- arr 是父组件的-->
<ppx :data="arr"></ppx>
</div>
let obj = {
props:['data'],
template:`
<ul>
<li v-for="(val,key) in data">
{{val}}
</li>
</ul>
`,
data(){
return {
val:'我是子组件'
}
}
} Vue.component('ppx',obj);
new Vue({
el:'#app',
data:{
arr:[111,222,333]
}
});
子级传递父级
change(){
this.$emit('customev',id,xxx)
}
<div id="app">
<h2>父组件</h2>
<input type="text" v-model="val" @keyup.13="add" >
{{arr}}
<h4>子组件</h4>
<ppx :data="arr" @changebool="ck"></ppx>
</div>
let obj={
props:{
data:{
type:Array,
default:[]
}
},
template:`
<div>
<ul>
<li v-for="(val,key) in data">
<input type="checkbox" @click="changeC(val.id,$event)">
<span>{{val.name}}</span>
</li>
</ul>
</div>
`,
methods:{
changeC(id,ev){
//自定义的changebool事件,触发时候执行ck
this.$emit('changebool',id,ev.target.checked);
}
}
}
Vue.component('ppx',obj);
new Vue({
el:'#app',
data:{
val:'',
arr:[
{
id:0,
name:'巴黎',
checked:false
},
{
id:1,
name:'东京',
checked:false
},
{
id:2,
name:'伦敦',
checked:true
},
{
id:3,
name:'悉尼',
checked:false
}
]
},
methods:{
add(){
this.arr.push({
id:+new Date,//隐式类型转换,可以把字符串转成数字类型
name:this.val,
checked:false
});
this.val = '';
},
ck(id,bool){
this.arr.forEach(e=>{
//如果当前的id 等于 id 就把当前数据的checked 赋给 bool
if(e.id === id){
e.checked = bool;
}
})
}
}
});
另一种方法
<div id="app">
<h2>父级的</h2>
<input type="text" v-model="val" @keyup.13="add">
{{arr}}
<hr> <h2>子组件</h2>
<list :data="arr" :k="kk" @getchilddata="changeC"></list>
</div>
let obj = {
template:`
<div>
<ul>
<li v-for="(val,key) in cd">
<input
type="checkbox"
@change="changeFn(val.id)"
>
<span>{{val.txt}}</span>
</li>
</ul>
{{cd}}
</div>
`,
methods:{
changeFn(id){
let b;
this.cd.forEach(data => {
if(data.id === id){
data.checked = !data.checked;
b = data.checked;
}
}); this.$emit('getchilddata',id,b);
console.log(this.cd); }
},
props:['data','k'],
data(){
return {
cd:JSON.parse(JSON.stringify(this.data))
}
}
} Vue.component('list',obj); new Vue({
el:'#app',
data:{
kk:'变',
val:'',
arr:[
{
id:0,
txt:'小明',
checked:false
},
{
id:1,
txt:'小红',
checked:false
},
{
id:2,
txt:'小刚',
checked:false
}
]
}
,methods:{
add(){
this.arr.push({
id: +new Date,
txt:this.val,
checked:false
});
this.val = '';
},
changeC(id,bool){
this.arr.forEach(e=>{
if(e.id === id){
e.checked = bool;
};
});
}
}
});
vue 组件数据传递的更多相关文章
- vue教程3-05 vue组件数据传递、父子组件数据获取,slot,router路由
vue教程3-05 vue组件数据传递 一.vue默认情况下,子组件也没法访问父组件数据 <!DOCTYPE html> <html lang="en"> ...
- React中父子组件数据传递
Vue.js中父子组件数据传递:Props Down , Events Up Angular中父子组件数据传递:Props Down, Events Up React中父子组件数据传递:Prop ...
- Vue之数据传递
基础:vue的响应式规则 简单的props更新 父组件 <template> <div> <block-a :out-data="x">< ...
- 关于vue.js父子组件数据传递
vue.js中使用props down,events up的原则进行父子组件间的通信,先来记录下props down,看个例子: <div id="app2"> < ...
- vue组件 Prop传递数据
组件实例的作用域是孤立的.这意味着不能(也不应该)在子组件的模板内直接引用父组件的数据.要让子组件使用父组件的数据,我们需要通过子组件的props选项. prop 是单向绑定的:当父组件的属性变化时, ...
- vue 多级组件数据传递
A包含B组件,B包含C组件 那么A 传递到C 组件可以通过 在B组件中绑定 $attrs 具体代码可以参见github: https://github.com/qiaoqiao10001/vueA ...
- vue2.0 父子组件数据传递prop
vue的一个核心概念就是组件,而组件实例的作用域是孤立的,所以组件之间是不能直接引用其他组件的数据的.极端点举例来说,就是可以在同一个项目中,每一个组件内都可以定义相同名称的数据. data () { ...
- Vue2.x中的父组件数据传递至子组件
父组件结构 template <template> <div> <v-girl-group :girls="aGirls"></v-gir ...
- Vue2.x之父子组件数据传递
父传子,并且通过fatherEvent接收子组件传过来的值 <template> <div class='father'> <Son :fatherData=" ...
随机推荐
- jupyter更改存储路径
实习了两个月爬虫,第一个月学到了不少东西,尤其是真实链接的抓取还有定时爬虫以及一些常规的反爬策略. 但是感觉第二个月的工作内容和预想的轨道渐渐脱离,所以选择了辞职,停下来重新看一下以后的路该怎么走,调 ...
- 【QML与C++混合编程】用QVariantList传递数组类型成员
2017.5.8 更新:Record类要用指针,QObject 不能有拷贝函数. 我有一个C++中自定义的ReaderModel,继承自QAbstractListModel类,传递给了QML. 它的m ...
- Android assets的一个bug
摘要 Android assets目录下资源文件超过1MB的问题. 由于要显示一些奇奇怪怪的日文字符,我们在应用里放了一个字库文件,譬如叫做jp.ttf,放在assets目录下打包. 开发.调试一切正 ...
- 【BZOJ3874】[AHOI&JSOI2014]宅男计划(贪心,三分)
[BZOJ3874][AHOI&JSOI2014]宅男计划(贪心,三分) 题面 BZOJ 洛谷 题解 大力猜想一最长的天数和购买外卖的总次数是单峰的.感性理解一下就是买\(0\)次是\(0\) ...
- 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)
[BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...
- Nifi InvokeHttp processor
Authorization: Bearer <access-token> Content_type: application/json NIFI 中国社区 QQ群:595034 ...
- LOJ6089 小Y的背包计数问题(根号优化背包)
Solutioon 这道题利用根号分治可以把复杂度降到n根号n级别. 我们发现当物品体积大与根号n时,就是一个完全背包,换句话说就是没有了个数限制. 进一步我们发现,这个背包最多只能放根号n个物品. ...
- centos7搭建ELK Cluster集群日志分析平台(四):Fliebeat-简单测试
续之前安装好的ELK集群 各主机:es-1 ~ es-3 :192.168.1.21/22/23 logstash: 192.168.1.24 kibana: 192.168.1.25 测试机:cli ...
- ftp sun jdk自带
package com.italktv.colnv.stat.util; import java.io.File; import java.io.FileInputStream; import jav ...
- CF747F Igor and Interesting Numbers
我佛了,这CF居然没有官方题解. 题意:给定k,t,求第k小的16进制数,满足每个数码的出现次数不超过t. 解: 每个数都有个出现次数限制,搞不倒.一开始想到了排序hash数位DP,不过写了写觉得不胜 ...