Vue props父组件向子组件传值详解

摘要:
我们可以说,在vue的官方网站上有我们想要的一切。首先,通过prop粘贴价值转移的官方网站地址:通过prop向子组件转移数据的prop是什么?从这句话中,我们可以看出两点:1。道具写在组件上。道具在组件上。高级——动态价值转移当我第一次学习vue时,我总是不知道props的过程是什么,也就是说,我是先创建组件还是先声明vue实例。3.实例上的数据值应与props声明的值相对应。

vue官网上可以说有我们想要的一切,先贴上通过prop传值的官网地址通过prop向子组件传递数据

Prop是什么?

  Prop是你可以在组件上注册的一些自定义特性。当一个值传递给一个prop特性的时候,它就变成了那个组件实例的一个属性

  从这句话上面我们能看出两点

  1、prop是写在组件上的。

  2、把父组件的一个值传给子组件时,这个值通过prop转化成了这个子组件实例的一个属性。

  

  不理解第二句话没关系,看下面例子。

基础--静态传值

  1、首先创建一个Vue实例

  2、注册一个组件(这样注册组件的方式是全局注册),还记得我们第一句话吗?prop是在组件上的。因为可以是多个,所以是props。

    在props上声明的是title,在我们的template模板中使用的都是它。

  3、使用组件。

<script>
        //第二步: 注册一个全局组件
        Vue.component('props-component', {
            // 在这个组件上声明props
            props:['title'],
            template:`
                <div>{{title}}</div>
            `
        });
        // 第一步:声明Vue
        let vm = new Vue({
           el:'#app' 
        });
    </script>
<div id="app">
        <!-- 第三步:使用组件 -->
        <props-component title="props so easy"></props-component>
    </div>

  这只是一个非常简单的静态传值,可在实际中我们几乎不用静态传值。

进阶--动态传值

  我刚学习vue的时候,一直不知道props的流程到底是怎么样的,也就是我是先创建组件,还是先声明一个vue实例等等。流程很重要,

  也可以说这种思想很重要。

  说下我的理解:

  1、首先我们应当知道自己创建的组件里面是什么标签啊之类的。我应用到哪个地方?具体模板应该是什么样子的?

    就像我们上面例子中的这个最简单的模板。

<div>{{title}}</div>

  2、声明组件上的props。

  3、实例上的data值应当和props声明的值对应。

  看下面的例子:

  场景:我想写一个页面的header标签组件。

  

 第一步:

// 第一步:声明Vue
        let vm = new Vue({
           el:'#app',
           data:{
                
           }
        });

第二步:这个组件应当长什么样子?

        // 第二步:创建组件
        Vue.component('my-header', {
            props:['lists'],
            template:`
                <header>
                    <ul>
                        <li>{{lists}}</li>
                    </ul>
                </header>
            `
        })

第三步:声明headerList(其实熟练的话,这步骤完全省略了)

let vm = new Vue({
           el:'#app',
           data:{
                headerList:'首页'
           }
        });

第四步:使用组件 :lists="headerList"

    lists是我们在组件中props声明的,headerList是我们在根实例中声明的属性

<my-header :lists="headerList"></my-header>

这样就是一个最简单的组件传值了。

打完收工

免责声明:文章转载自《Vue props父组件向子组件传值详解》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇【网络】默认路由(路由黑洞,路由终结)软件开发所需要的十三个文档下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

Hibernate 数据的批量插入、更新和删除

对于这个批处理场景,Hibernate提供了一个批处理解决方案。接下来,我们将从批插入、批更新和批删除三个方面介绍如何处理此批处理场景。为了避免这种情况,Hibernate为批量更新和批量删除提供了类似于SQL的HQL语法。...

arcgispro 计算字段示例

使用两个或四个空格来定义每个逻辑级别。Python计算表达式字段将使用感叹号(。简单计算简单字符串示例一系列Python字符串函数支持使用字符串。字符串字段中的字符可以通过索引和拆分操作访问“”bcd“”Python还支持使用format()方法的字符串格式!)常用Python字符串操作简单数学示例Python提供了处理数字的工具。...

用arduino做一个智能垃圾桶

这些天我几乎很忙。我有一些时间继续打扰我的arduino。上一次我从TB购买arduino套件时,有一个人体热能感应模块,用于感应人体接近信号。今天我们用这个做一个简单的智能垃圾桶。要实现的功能是:当有人靠近时,垃圾可以自动打开盖子,当人离开时,盖子可以自动关闭。1、 所需材料和工具:1 Arduino SCM我使用Arduino Nano 2人体热能传感模...

winform中 跨线程启动UI

C#的winform程序中,是不可以从UI窗口主线程之外的线程去直接操作窗口控件的。确切的解释是,不能从创建控件的线程以外的线程去处理控件的操作,比如修改属性等。方法二,通过Control.Invoke调用委托的方式来执行。...

ERROR [IM002] [Microsoft][ODBC 驱动程序管理器] 未发现数据源名称并且未指定默认驱动程序

使用C#生成应用程序以及读取和写入dbfs时,打开方法error[IM002][Microsoft][ODBC驱动程序管理器]中发生错误。找不到数据源名称,也未指定默认驱动程序。这个程序以前使用得很好。升级和修改后,在测试中发现了问题。为了追踪来源,我曾经是一个32位操作系统。现在我安装了一个win764位操作系统。从控制面板到管理工具再到ODBC驱动程序,...

Dto和Entity如何优雅的相互转换

什么是Dto,Entity,用来干什么?这个时候就有一个麻烦事,Entity和Dto的互转。通常的转换方法有两个途径,一个是通过反射的方式,来进行对象属性的复制;另一种是,通过硬编码进行对象属性的赋值;1.在service层中添加实体类转换函数@ServicepublicMyEntityService{publicSomeDtogetEntityById{S...