zoukankan      html  css  js  c++  java
  • [vue]子组件通过props获取父组件数据以及使用watch解决动态数据不生效问题

    父子组件的传值,在Vue官方也写得很清楚,父组件中使用v-bind绑定传送,子组件使用props接收。

    父组件通过v-bind绑定数据:

    <template>
        <router-view :yourdata="yourdata"></router-view>
    </template>
    <script>
    export  default {
        data:function() {
            return {
                yourdata:"这是一段测试文字。",
            }
        }
    }
    </script>

    子组件使用props接收数据:

    <template>
        <div>{{yourdata}}</div>
    </template>
    <script>
    export  default {
        props: ['yourdata']
    }
    </script>

    但,如果父组件的yourdata是一个动态的数据,比如是使用axios动态请求的数据,那么这个数据是不会在子组件中变更的,那么就要用到watch:

    <template>
        <div>{{newdata}}</div>
    </template>
    <script>
    export  default {
        data:function(){
            return{
                newdata:"",
            }
        },
        props: ['yourdata'],
        watch:{
            yourdata:function (newVal,oldVal) {
                this.newdata=newVal;//newVal就是获取的动态新数据,赋值给newdata
            }
        }
    }
    </script>

    快去尝试一下吧~

  • 相关阅读:
    表数据转换为insert语句
    Google Map Api 谷歌地图接口整理
    VS预生成事件命令行 和 生成后事件命令行
    C#程序开机运行
    枚举数据源化
    winform分页管理
    数据库访问驱动
    sql时间格式
    sysobjects.xtype介绍
    编码标准的多样性
  • 原文地址:https://www.cnblogs.com/rakich/p/13456554.html
Copyright © 2011-2022 走看看