总结Vue第二天:自定义子组件、父子组件通信、插槽

简介: 总结Vue第二天:自定义子组件、父子组件通信、插槽

总结Vue第二天:自定义子组件、父子组件通信、插槽


一、组件:

组件目录

1、注册组件(全局组件、局部组件和小demo)

2、组件数据存放

3、父子组件通信(父级向子级传递数据、子级向父级传递数据)

4、父子组件存储数据的访问:

5、 插槽slot

 

1、注册组件(全局组件、局部组件和demo、template模块):

(1)注册组件的基本步骤:

创建组件构造器对象 Vue.extend( ); 方法【可以省略】

注册组件 Vue.component({组件的标签名:组件构造器对象} );

使用组件,在Vue实例的作用域范围内使用

(2)全局组件demo:


<div id="app">
    <runoob></runoob>
</div>
<script>
// 注册
Vue.component('runoob', {
  template: '<h1>自定义组件!</h1>'
})
// 创建根实例
new Vue({
  el: '#app'
})
</script>

(3)局部组件demo:


<div id="app">
    <runoob></runoob>
</div>
<script>
var Child = {
  template: '<h1>自定义组件!</h1>'
}
// 创建根实例
new Vue({
  el: '#app',
  components: {
    // <runoob> 将只在父模板可用
    'runoob': Child
  }
})
</script>


(4)template模块的简化(模板的分离写法):即将其内容封装到 template 标签里。


<!-- 使用组件 -->
<my-cpn></my-cpn>
<!-- 模板 -->
<template id="cpn">
  <div>
    <h1>nihao</h1>
  </div>
</template>
  let app = new Vue({
    el: '#app',
    components: {
      'my-cpn': {template: `#cpn`}
    }
  });


2、组件数据存放:

(1)组件对象也有一个data属性

(2)☆这个data属性必须是一个函数,且函数返回一个对象,对象内部保存着数据

 image.png


3、父子组件通信(父级向子级传递数据、子级向父级传递数据)

(1)父级向子级传递数据【Prop】:

● Prop:子组件在自身标签上,使用自定义的属性来接收外界(也可以是父组件)的数据,然后将数据接收到prop中。【接收父组件的数据—动态Prop,需要v-bind绑定属性,数据可以从vue实例中获取】


<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>html暂时不支持驼峰写法</title>
</head>
<body>
<div id="app">
  <!--
   子组件要或者外界(例如也可以是父组件)的数据,它是需要在自身标签上,使用props中自定义的属性来接收,
   若是想接收的数据来自父组件【Vue实例】------通过绑定属性(数据可以从vue实例中获取)
  -->
  <!--静态的prop-->
  <cpn c-info="info"></cpn><br/>
  <!--动态prop-->
  <cpn :c-info="info"></cpn>
</div>
<template id="cpn">
  <div>
    <h1>cpn的内容</h1>
    <ul>
      <li v-for="item in cInfo">{{item}}</li>
    </ul>
  </div>
</template>
</body>
<script type="text/javascript" src="./js/vue.min.js"></script>
<script>
  const cpn = {
    template: `#cpn`,
    props:{
      cInfo: {
        type: Object,
        default(){
          return {}
        }
      }
    },
  }
  let app = new Vue({
    el: '#app',
    data: {
      message:'动态绑定属性v-bind',
      abc: {
        id: '1',
        name: '父类的info中的name',
        age: '1'
      },
      info: {
        id: '1',
        name: '父类的info中的name',
        age: '15'
      }
    },
    components: {
      cpn
    }
  });
</script>
</body>
</html>


ps:Prop 验证(组件可以为 props 指定验证要求):


Vue.component('my-component', {
  props: {
    // 基础的类型检查 (`null` 和 `undefined` 会通过任何类型验证)
    propA: Number,
    // 多个可能的类型
    propB: [String, Number],
    // 必填的字符串
    propC: {
      type: String,
      required: true
    },
    // 带有默认值的数字
    propD: {
      type: Number,
      default: 100
    },
    // 带有默认值的对象
    propE: {
      type: Object,
      // 对象或数组默认值必须从一个工厂函数获取
      default: function () {
        return { message: 'hello' }
      }
    },
    // 自定义验证函数
    propF: {
      validator: function (value) {
        // 这个值必须匹配下列字符串中的一个
        return ['success', 'warning', 'danger'].indexOf(value) !== -1
      }
    }
  }
})


(2)子级向父级传递数据【emit】:

● 子组件通过$emit(‘自定义事件名’, 数据变量)向父组件发送消息,在子组件进行自定义的事件进行监听【监听调用的函数可以直接通过一个自定义的参数接收到数据变量】


<!-- 父组件 -->
<div id="app">
  <!-- 子组件上监听到自定义的事件的同时,也监听到发送的数据num,事件指向的函数,通过自定义一个参数value可以直接拿到数据num  -->
  <cpn :c-info="info" @item-click="itemClick"></cpn>
</div>
<!-- 子组件的模板 -->
<template id="cpn">
  <div>
    <h1>子组件的模板</h1>
      <button v-for="item in cInfo"  @click="btnClick(item)">{{item}}</button>
  </div>
</template>
</body>
<script type="text/javascript" src="js/vue.min.js"></script>
<script>
  const cpn = {
    template: `#cpn`,
    data(){
      return{
        num: 99
      }
    },
    props:{
      cInfo: {
        type: Object,
        default(){
          return {}
        }
      }
    },
    methods: {
      btnClick(item){
        console.log('子组件接收到父组件传递的数据' + item);
        //$emit的第一个参数是自定义的事件名称和发送数据num
        this.$emit('item-click', this.num);
      }
    }
  }
  let app = new Vue({
    el: '#app',
    data: {
      info: {
        id: '1',
        name: 'yile',
        age: '15'
      }
    },
    methods: {
      itemClick(value){
        console.log('父组件监听到子组件发出的事件和接收到子组件的数据' + value);
      }
    },
    components: {
      cpn
    }
  });
</script>

4、Vue父子组件存储数据的访问:

(1)父组件访问子组件data中存储的数据:使用childrenchildren或refs

(注意:this.$children得到的是一个数组,包含所有子组件对象。)

(2)$refs的使用:

      ■ $refs和ref指令通常是一起使用的

        ■ 首先,我们通过ref给某一个子组件绑定一个特定的ID

        ■ 其次,通过this.$refs.ID就可以访问到该组件了


12.png


(3)子组件访问父组件:使用$parent

 

二、插槽slot

1、编译作用域:

父组件模板的所有东西(例如变量)都会在父级作用域内编译;子组件模板的所有东西都会在子级作用域内编译。

2、slot基本使用:

3、具名插槽slot:

 


目录
相关文章
|
5天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
109 64
|
12天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
28 1
vue学习第四章
|
12天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
25 1
vue学习第九章(v-model)
|
12天前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
27 1
vue学习第十章(组件开发)
|
18天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
18天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
18天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
18天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
17天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
26 3
|
19天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。