vue-组件父传子

  • i. 父子组件传值 (props down, events up)
  • 假设第二层组件想和第一层组件进行通信,分析其传值过程
    (第一层向第二层传值):父组件通过props传值到子组件,如此便实现父子组件向下通信
  • ii. 属性验证 props:{name:Number}
    Number,String,Boolean,Array,Object,Function,null(不限制类型)
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Examples</title>
    <style>
        .navbar {
            background: red;
        }
    </style>
</head>
<body>
    <div id="box">
        <!--myname为自定义属性,属性值会被当成字符串对待,需要动态绑定-->
        <navbar myname="home" :myshow="false"></navbar>
        <navbar myname="list" :myshow="true"></navbar>
        <navbar myname="parentname" :myshow="true"></navbar>
        <!--动态绑定传值-->
        <navbar :myname="parentname" :myshow="true"></navbar>
    </div>

    <script src="http://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script type="text/javascript">
    //全局组件
        Vue.component("navbar", {
            template: `<div>
          <button>返回</button>  
          navbar -- {{myname}}
          <button v-show="myshow">首页</button>  
        </div>`,
            // props:["myname","myshow"] // 接受父组件传来的属性
            props: {
                myname: String,  //属性验证
                myshow: Boolean
            }
        })

        new Vue({
            el: "#box",
            data: {
                parentname: "父组件的状态"
            }
        })
    </script>
</body>
</html>
Vue2中,可以通过Props属性实现组件之间的父传子通信。父组件可以通过在子组件上定义Props属性,并在使用子组件的地方通过属性绑定的方式向子组件传递数据。具体步骤如下: 1. 在子组件中定义Props属性,用于接收父组件传递的数据。例如,在子组件的脚本中使用props选项定义一个名为title的属性: props: ['title'] 2. 在父组件中使用子组件,并通过属性绑定的方式向子组件传递数据。例如,在父组件的模板中使用子组件,并通过title属性向子组件传递数据: <ChildComponent :title="父组件的数据"></ChildComponent> 其中,:title是属性绑定的语法,将父组件的数据绑定到子组件的title属性上。 3. 在子组件中可以使用props属性接收父组件传递的数据,并在子组件的模板中使用该数据。例如,在子组件的模板中可以使用{{ title }}来显示父组件传递过来的数据。 这样就实现了Vue2中组件之间的父传子通信。通过在子组件上定义Props属性,并在父组件中使用属性绑定的方式向子组件传递数据,可以实现父组件向子组件传递数据的目的。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue3 - 组件通信(父传子)](https://blog.csdn.net/weixin_44198965/article/details/127875160)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值