1.父组件向子组件传递数据
<div id="box"> <aaa></aaa> </div>
<template id="aaa">
<h1>模板aaa=>{{msg1}}</h1> //msg1写在这里是可以的,因为这是父组件内部
//<bbb>{{msg1}}</bbb> //这种写法是不可以的,这是在子组件内部,要在这里显示父组件的数
//据,需要用props定义属性
<bbb :m='msg1'></bbb>
</template>
var vm=new Vue({
el:"#box",
data () {
a:'aaa'
},
components:{
'aaa':{
data () {
msg1:'父组件的数据'
},
template:'#aaa',
components:{
'bbb':{
// props:['m'], //这是一种写法,props以数组的形式定义属性
props:{
'm':String //这是第二种写法,对象的形式
},
template:'<h3>这是子组件bbb--{{m}}</h3>'
}
}
},
}
})
从这个例子中可以看出,父组件向子组件传递数据,因为每一个组件都是独立的作用域,所以要把父组件的数据在子组件中显示,要使用props定义属性来绑定父组件里面的数据才可以,如这里父组件的数据是msg1,用props定义一个属性m,来接收数据msg1;在子组件的模板里面用{{m}}的形式显示父组件的数据
父组件不仅可以向子组件传递数据,也可以传递方法,如:
<edit-issue :title='issueTitle' :is-show.sync='modelIssue' :model-type.sync='modeltype' :issue-datas='listdb' :user.sync='users' :projects="projectDatas" :get-datas="getCreateIssues" :localtoken="localtokenId" :user- name="userName" :token-data="tokendata"> </edit-issue>
这是一个子组件,引用在父组件中,其中的 :get-datas=”getCreateIssues” 接收的是一个方法,这个方法在父组件中从后台获取数据传递给子组件,在子组件中就可以展示这些数据,
methods:{
getCreateIssues(){ //这是es6的格式
this.$http.get(url,data).then(res=>{}) //这也是es6的格式
}
}
在子组件中
复制代码 代码如下:
props:['executorsData','isShow','modelType','issueDatas','user','projects','title','getDatas','getEditData','localtoken',"userName","tokenData"],
getDatas就是从父组件中接收数据的方法,对应上面的 :get-datas=”getCreateIssues”,在子组件可以直接使用getDatas这个方法,如:
methods:{
okConfirm(){
issueApi.delIssue(this.delId).then(res=>{
if(res.data.code==0){
this.successPop('删除成功');
this.openConfirm=false;
this.isShow=false;
//这里就是使用的父组件的方法
this.getDatas();
//end
this.$dispatch('fetchList');
}else{
this.warningPop(res.data.message)
}
})
},
}
2.子组件向父组件传递数据
在子组件中选择条件后,在父组件中执行搜索功能
<div class="task-btn"> <p @click="clear()">清空</p> <p @click="confirm(modalData)">搜索</p> //modalData是需要向后台发送的数据 </div>
export default{
props:['confirm'],
data(){
return {
modalData:{ProjVerName:''}
}
}
}
定义一个confirm方法接收父组件中的方法,这里从子组件向父组件传递数据不是按照教程上的方法使用$emit,而是直接把数据作为参数传递到方法中,在父组件中这样使用:
<issuesearch :confirm="search" :showtotal.sync="showtotal" :is-re-get.sync="isReGet" :type="chosenType"> </issuesearc>
data(){
return {
searchData:{
ProjVerName:'',
}
}
},
methods:{
search(data){ //data就是接收子组件传递过来的数据的形参
this.searchData.ProjVerName=data.ProjVerName;
this.$http.get(url,this.searchData.ProjVerName).then(res=>{
console.log(res)
})
}
}
这种方法就是从子组件向父组件传递数据,
从子组件向父组件传递方法,需要使用$dispatch,如:
在子组件中点击保存以后,这个弹出框消失,父组件中需要获取一遍最新数据,这种情况就需要把这个保存事件发送出去,让父组件知道,用法:
复制代码 代码如下:
<div class="creator-btn fr margintop" @click="save()" v-if="(modelType=='edit')&&(issueDatas.state!==5)">保存</div>
methods:{
save (){
this.$http.post(url,data).then(res=>{
console.log('保存成功');
this.$route.router.go({
name:'issues.issueList'
}); //保存完以后跳转到对应的路由
this.$dispatch('disSave') //这里把保存事件发送出去
})
}
}
在父组件中使用events来接收这个事件,并执行一些动作,如:
events:{
disSave(){ //这就是接收的子组件的方法
this.getCreateIssues(); //接收完以后调用一个方法获取一遍数据,这样就实现了在子组件中点击保存后,父组件能直接获取到最新的数据
}
},
关于子组件向父组件传递数据也可以使用教程里的方法,使用$emit
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue父子组件传递数据
# vue
# 组件传递数据
# vue父子组件
# 对象传递
# Vue 父子组件数据传递的四种方式( inheritAttrs + $attrs + $listen
# Vue表单类的父子组件数据传递示例
# Vue 父子组件的数据传递、修改和更新方法
# Vue2.0父子组件传递函数的教程详解
# Vue父子传递实例讲解
# 这是
# 一遍
# 从子
# 的是
# 都是
# 这就是
# 不可以
# 是从
# 要在
# 要把
# 这是一个
# 才可以
# 弹出
# 可以直接
# 这种情况
# 可以使用
# 可以看出
# 这是一种
# 写在
# 中就
相关文章:
建站之星如何保障用户数据免受黑客入侵?
定制建站是什么?如何实现个性化需求?
如何高效配置IIS服务器搭建网站?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
开封网站制作公司,网络用语开封是什么意思?
如何快速搭建响应式可视化网站?
自助网站制作软件,个人如何自助建网站?
如何快速打造个性化非模板自助建站?
建站之星代理费用多少?最新价格详情介绍
广州建站公司哪家好?十大优质服务商推荐
建站之星价格显示格式升级,你的预算足够吗?
Android自定义控件实现温度旋转按钮效果
如何选择高效响应式自助建站源码系统?
免费网站制作appp,免费制作app哪个平台好?
如何在自有机房高效搭建专业网站?
深圳网站制作的公司有哪些,dido官方网站?
如何快速生成高效建站系统源代码?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
5种Android数据存储方式汇总
模具网站制作流程,如何找模具客户?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
制作表格网站有哪些,线上表格怎么弄?
广东专业制作网站有哪些,广东省能源集团有限公司官网?
寿县云建站:智能SEO优化与多行业模板快速上线指南
家具网站制作软件,家具厂怎么跑业务?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
如何快速生成凡客建站的专业级图册?
如何用VPS主机快速搭建个人网站?
建站之星如何实现网站加密操作?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
如何用PHP工具快速搭建高效网站?
如何快速搭建高效WAP手机网站吸引移动用户?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
建站主机如何选?高性价比方案全解析
javascript基本数据类型及类型检测常用方法小结
宝塔建站教程:一键部署配置流程与SEO优化实战指南
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
官网网站制作腾讯审核要多久,联想路由器newifi官网
视频网站制作教程,怎么样制作优酷网的小视频?
如何快速生成ASP一键建站模板并优化安全性?
非常酷的网站设计制作软件,酷培ai教育官方网站?
如何快速辨别茅台真假?关键步骤解析
如何选择高性价比服务器搭建个人网站?
青浦网站制作公司有哪些,苹果官网发货地是哪里?
小建面朝正北,A点实际方位是否存在偏差?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
建站主机是否属于云主机类型?
如何破解联通资金短缺导致的基站建设难题?
网站制作壁纸教程视频,电脑壁纸网站?
如何用AWS免费套餐快速搭建高效网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。