意见箱
恒创运营部门将仔细参阅您的意见和建议,必要时将通过预留邮箱与您保持联络。感谢您的支持!
意见/建议
提交建议

Vue中props用法是什么,具体如何应用

来源:恒创科技 编辑:恒创科技编辑部
2024-01-21 04:29:59
关于“Vue中props用法是什么,具体如何应用”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。



Vue中props用法是什么,具体如何应用

​前言:

在Vue中通过props,可以将原本孤立的组件串联起来,也就是可以子组件可以接收父组件传递过来的data,比如子组件想要引用父组件的数据,那么在props里面声明一个变量,这个变量就可以引用父元素的数据。

实例演示:

子组件:

<template>

  <div>

    <h3>我是{{name}},今年{{age}}岁,爱好:{{hobby}}</h3>,{{flag}}

  </div>

</template>



<script>

export default {

    name:'Cpn',

    // 简单接收

    /* props:['age','hobby','name'], */

    // 声明要接收的数据,声明时对接收的数据进行限制

    props:{

        name: {

            // 声明类型

            type:String,

            //声明是否必需

            require:true,

            // 声明默认值

            default:'默认值'

        },

        age:{

            type:Number,

            require:true,

            default:18

        },

        hobby:{

            type:String,

            require:false

        },

        flag:{

            type:Boolean,

            require:false

        }

    }

}

</script>

父组件:

<template>

  <div id="app">

    <!-- <cpn name='李明' age="22" hobby="打球"></cpn>

    <cpn name="小红" age="20" hobby="弹琴"></cpn> -->

    <cpn name='李明'></cpn>

    <cpn hobby="编程" :flag="flag"></cpn>

      <!--备注:如果要将当前组件data里的数据传递给子组件,需要通过v-bing:变量名=”变量名“的形式传递,如果传递的不是data里面的数据,就不用加绑定指令,即v-bind(可简写为:)-->

    <button @click="changeFlag">切换</button>

  </div>

</template>

<script>

import Cpn from './components/Cpn.vue'

export default {

  components: { Cpn },

  name: "App",

  data() {

    return {

      flag:false

    }

  },

  methods: {

    changeFlag(){

      console.log(this.flag)

      this.flag=!this.flag;

      console.log(this.flag)

    }

  },

}

</script>

运行上面的程序可以看到,当我们通过点击父组件的按钮切换某个值时,子组件接收的值也会相应变化。

子组件接收父组件的数据有两种接收方式:

方式1:简单接收, 只需要给出所要接收的变量的名字即可 方式2: 具体接收,给每个接收的变量选择性地指明数据类型,是否可为空,默认值
以上就是关于“Vue中props用法是什么,具体如何应用”的介绍了,感谢各位的阅读,如果大家想要了解更多相关的内容,欢迎关注恒创科技,小编每天都会为大家更新不同的知识。
上一篇: JS中遍历子元素的方法是什么,使用有什么要注意的 下一篇: 手机怎么远程登录云服务器?