在学java面向对象的时候,想必大家都听过这样一句话“万事万物皆对象”,如今我们来到vue的时候,也有这样一句话“万事万物皆组件”,所以本篇文章将带领大家详细了解vue中最重要的一部分“Vue组件”

目录

一、Vue组件的组成部分:

二、如何在项目中注册组件?

2.1 全局注册

2.2 本地注册

三、各组件之间的参数传递:

3.1 父传子

3.2 子传父

3.3 改进版参数传递

 一、Vue组件的组成部分:

        Vue组件的组成可以分为三部分;分别是<template></template>、<Script></Script>、<style></style>

<template>
  <div id="app">

  </div>
</template>

<script>
  export default {
    name: 'app',
    data () {
    },
    methods: {},
    computed: {},
    watch: {}
  }
</script>

<style>

</style>

二、如何在项目中注册组件?

2.1 全局注册:

        组件的全局注册,是在main.js中,通过import 和Vue.component配合,来将一个Vue文件注册成一个标签,从而达到全局使用的效果。步骤流程如下:

组织架构展示vue_vue.js

 2.2 本地注册:

        进行组件的本地注册的时候,是在app.vue文件中导入需要注册成组组件的文件,比如:import Header from‘./component/Header’,然后在app.vue的<script>标签中使用component属性进行组件的声明。具体代码示例如下:

<template>
  <div id="app">

    <MHeader></MHeader>
    
</template>

<script>
  import MHeader from './components/Header.vue'
  export default {
    name: 'app',
    data () {
    },
    components: {
      "MHeader": MHeader
    }

  }
</script>

<style>

</style>

注:本地注册标签的时候,只能在注册的文件中进行标签的使用

三、各组件之间的参数传值:

        在进行参数传递前呢,我们首先要了解一个属性的使用‘props’  ,props是表示一个组件的参数部分,props的写法有两种,分别如下:

1、props:[参数列表],例如:props:[‘myTitle1’,‘myTitle2’],就是在props里放了两个属性,来接收其他组件传递过来的值

//  第一种参数类表
props:[‘myTitle1’,‘myTitle2’]

2、props: { 'myHeaderTitle': { type: String, required: true, default: 'xxxxxx' }, 'btf':{ type:Function } };该props表示定义了两个参数,分别是‘myHeaderTitle’,和‘btf’。其中myHeaderTitle表示的意思是:参数的类型是String,必须存在,当参数不存在时候默认值为‘xxxxxx’;btf参数表示的是,接收的参数是一个Function(函数类型)

/    第二种
    props: {
      'myHeaderTitle': {
        type: String,
        required: true,
        default: 'xxxxxx'
      },
      'btf':{
          type:Function
      }
    }

3.1 父传子

        各组件之间的传值--父传子,是在子组件中通过props属性来定义需要接收值的属性,通过插值表达式获取vue对象中的属性值(属性值来自于data、computed、props),其中props里放的是其他组件传递过来的值,在父标签中通过使用在标签中写明参数的键值对来传递参数。流程如下:

组织架构展示vue_ecmascript_02

 

3.2 子传父 

        子传父这种方式是比较复杂的一种传参方式,将采取分开梳理的方式,分别对子、父标签进行讲解以及整体梳理

        子标签: 子标签中的props中定义了一个两个属性;分别是‘myHeaderTitle’,‘btf’,在子标签中对myHeaderTitle中的值进行页面展示。然后是在子标签中的定义了一个‘按钮’,当点击的时候调用btf函数,将btf函数声明在props标签中。代码如下:

<template>
  <div id="app">
    <!--{{msg}}-->
    <h1>我是header</h1>
    {{myHeaderTitle}}

    <button @click="btf('hello java')">点我</button>
  </div>
</template>

<script>
  export default {
    name: 'app',
    data () {
      return {
        msg: 'Welcome to Your Vue.js App'
      }
    },
//  第一种参数类表
//      props:['myHeaderTitle'] /
//    第二种
    props: {
      'myHeaderTitle': {
        type: String,
        required: true,
        default: 'xxxxxx'
      },
      'btf':{
          type:Function
      }
    }
  }
</script>

<style>

</style>

            父标签:父标签中通过使用子标签对值分别进行接收传递

<template>
  <div id="app">

    <myHeader :myHeaderTitle="msg" :btf="mybtn"></myHeader>
  </div>
</template>

<script>
  import MHeader from './components/Header.vue'
  export default {
    name: 'app',
    data () {
      return {
        msg:'myHeaderTitlemyHeaderTitlemyHeaderTitlemyHeaderTitle'
      }
    },
    methods:{
        mybtn:function (inf) {
          this.msg=inf;
        }
    }
  }
</script>

<style>

</style>

        代码块执行流程如下:

组织架构展示vue_组织架构展示vue_03

 在按钮未点击之前执行的是一个父传子的过程,在按钮点击后执行的是子传父过程,然后修改myHeaderTitle的值回显到页面上

3.3 改进版参数传递

        改进版参数传递是以事件发射的方式来实现子传父的效果,通过在子组件中使用this.$emit(“键”,“值”),在父组件中使用的子标签中使用@键=‘msg=$event’,其中$event就能得到子组件传的值,msg是父组件中的属性。

        子标签定义如下:

<template>
    <div id="app">
      <button @click="DoClick">我是content,点我</button>
    </div>
</template>

<script>
    export default {
        name: 'app',
      methods:{
        DoClick(){
            this.$emit("newName","小王")
        }
      }
    }
</script>

<style>

</style>

        父组件定义如下:

<template>
  <div id="app">

    <!--改进版参数传递-->
    <myContext @newName="msg=$event"></myContext>
  </div>
</template>

<script>
  import MHeader from './components/Header.vue'
  export default {
    name: 'app',
    data () {
      return {
        msg:'myHeaderTitlemyHeaderTitlemyHeaderTitlemyHeaderTitle'
      }
    }
  
  }
</script>

<style>

</style>