1.前言

  • 本节讲述vue组件的基本格式以及实际开发的应用场景,本节内容兼容Vue2.x与Vue3.x

2.组件基础

  • 组件的本质其实就是一个对象,这个对象包含多个属性,常见的属性有:template/data/methods/props/生命周期等
    var some_component = {
'template':"<h3>{{name}}</h3>",
data:function(){
return {
name:'child'
}
},
props:{},
methods:{ },
computed:{ },
created(){ }
}

3.模板定义的替代品

  • 通常情况下模版通过html字符串的形式复制给template属性,但是在js中拼接html字符串很不方便
  • 内联模板:在子组件标签中添加inline-template属性,会使用标签内的html模版代替原来的模版,但是props参数依然要传入,内联模版无法直接读取父组件的数据
<my-component inline-template :propsA="valueA">
<div>
<p>{{propsA}}</p>
</div>
</my-component>
  • X-Template:将html模版定义到script标签中,并通过id进行关联
<script type="text/x-template" id="hello-world-template">
<p>Hello hello hello</p>
</script>
Vue.component('hello-world', {
template: '#hello-world-template'
})

4.Vue 单文件组件 (SFC) 规范

  • 实际开发中,用上面的写法来定义一个组件是不明智的,就拿template为例,需要拼接大量的html字符串,既不方便编写,也不便于维护
  • 为了方便组件代码的封装复用,每一个组件对应一个vue文件,这个文件需要遵循 Vue 单文件组件 (SFC) 规范
  • 每个 .vue 文件包含三种类型的顶级语言块 template、script 和 style,其中template负责HTML模板,script负责js脚本,style负责样式
  • vue2.x只有一个根标签,vue3.x没有这个限制
<template>
<!-- vue2.x中只能有一个根标签 -->
<div>
<p>{{msg}}</p>
</div>
</template> // lang表示所使用的CSS 预处理语言
// scoped表示里面的样式作用范围此局限在此组件中
<style lang="less" scoped>
p{
color:green
}
</style> <script>
export default{
data(){
return{
msg:'hello wolrd'
}
},
methods:{
}
}
</script>

5.组件重载

  • 在Vue中,如果你想要重载一个组件,你可以通过更改component的key属性来强制重新渲染组件

6.组件的混入

  • Vue的混入功能支持将外部的数据或者逻辑注入到组件中,这些插入的数据或者逻辑会与组件本身的数据和逻辑进行合并
  • 实际开发的用法为:将通用的数据或者方法进行封装,需要时进行引入并配置到组件中,这样的话即扩展了组件的功能,也减少组件本身的代码量,便于维护
  • 在进行混入合并在过程中,有以下几个细节:
  • 对于混入的生命周期钩子,混入对象的钩子将在组件自身钩子之前调用
  • 对于data,methods,conputed,props,当他们的字段名产生冲突时,以组件本身的数据优先
<script>
//创建混入对象,用来给组件插入通用的数据或逻辑,包括data,props,methods,生命周期钩子等,这些插入的数据或者逻辑会与组件本身的数据和逻辑进行合并
//可以将通用的数据或者方法进行封装到单独某个文件中,需要时进行引入注册,从而减少代码量,便于维护
var mixin = {
data: function(){
return {
title:"混入的data数据"
}
},
created: function(){
console.log('我是混入的created钩子')
},
mounted:function(){
console.log('我是混入的mounted钩子')
},
methods:{
test(){
console.log('我是混入的方法')
}
}
}
var eChild = {
mixins: [mixin],
template:"<div>子组件1:{{typeof title == 'undefined'? '未定义title':title}}</div>",
data(){
return {
}
},
created(){
console.log('我是eChild的created')
},
mounted(){
console.log('我是eChild的mounted钩子')
},
}
var eChild2 = {
template:"<div>子组件2:{{typeof title == 'undefined'? '未定义title':title}}</div>",
data(){
return {
}
},
created(){
console.log('我是eChild2的created')
},
mounted(){
console.log('我是eChild2的mounted钩子')
},
}
var vm = new Vue({
el:"#app",
data(){
return { }
},
components:{
eChild,eChild2
},
})
</script>

Vue.js 组件基础的更多相关文章

  1. vue.js组件化开发实践

    前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎么实现,技术选型自然 ...

  2. VUE.JS组件化

    VUE.JS组件化 前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎 ...

  3. Vue.js—组件快速入门以及实例应用

    上次我们学习了Vue.js的基础,并且通过综合的小实例进一步的熟悉了Vue.js的基础应用.今天我们就继续讲讲Vue.js的组件,更加深入的了解Vue,js的使用.首先我们先了解一下什么是Vue.js ...

  4. 浅尝Vue.js组件(一)

    本篇目录: 组件名 组件注册 全局注册 基础组件的自动化全局注册 局部注册 在模块系统中局部注册 Prop 单向数据流 Prop验证 类型检查 非Prop特性 替换/合并已有的特性 禁用特性继承 自定 ...

  5. Vue.js—组件快速入门及Vue路由实例应用

    上次我们学习了Vue.js的基础,并且通过综合的小实例进一步的熟悉了Vue.js的基础应用.今天我们就继续讲讲Vue.js的组件,更加深入的了解Vue,js的使用.首先我们先了解一下什么是Vue.js ...

  6. Vue.JS学习基础

      = 导航   顶部 vue.js介绍 vue.js实例 模板语法 计算属性 样式绑定 条件渲染 列表渲染 事件处理器 表单控件绑定 组件   顶部 vue.js介绍 vue.js实例 模板语法 计 ...

  7. Vue.js应用基础

    声明 这篇博文是我的Vue学习记录,其中参杂了不少我个人的理解,由于我并没有继续学习Vue的源码,所以不能保证这些理解都是正确的.如果这篇博文有幸被你读到,请带着批判的心情去审视它. 如果你发现了其中 ...

  8. 如何理解vue.js组件的作用域是独立的

    vue.js组件的作用域是独立,可以从以下三个方面理解: 1.父组件模板在父组件作用域内编译,父组件模板的数据用父组件内data数据:2.子组件模板在子组件作用域内编译,子组件模板的数据用子组件内da ...

  9. Vue.js 组件编码规范

    本规范提供了一种统一的编码规范来编写 Vue.js 代码.这使得代码具有如下的特性: 其它开发者或是团队成员更容易阅读和理解. IDEs 更容易理解代码,从而提供高亮.格式化等辅助功能 更容易使用现有 ...

  10. Vue.js 组件的三个 API:prop、event、slot

    组件的构成 一个再复杂的组件,都是由三部分组成的:prop.event.slot,它们构成了 Vue.js 组件的 API.如果你开发的是一个通用组件,那一定要事先设计好这三部分,因为组件一旦发布,后 ...

随机推荐

  1. [JS设计模式]:鸭子类型与多态

    鸭子类型 编程语言按照数据类型大体可以分为两类,一类是静态类型语言,另一类是动态类型语言. 动态类型语言对变量类型的宽容给实际编码带来了很大的灵活性.由于无需进行类型检测,我们可以尝试调用任何对象的任 ...

  2. Encoder-Decoder、Seq2Seq、Attention

    Encoder-Decoder.Seq2Seq.Attention 传送门1:Encoder-Decoder 和 Seq2Seq 因为注意力不集中,所以这篇随笔就是看别人的文章,随手参考写写的. 1. ...

  3. CSS & JS Effect – 用 wheel 模拟 scroll

    前言 在 用 JavaScript 实现 position sticky 文章中,我提到了用 wheel 来模拟 scroll 效果. 这篇来说说具体怎么实现,挺简单的哦. Preparation t ...

  4. Atcoder Beginner Contest 367

    A.Shout Everyday \(\text{Diff }43\) 给你 \(24\) 小时制下的 \(A,B,C\) 三个时刻,问 \(A\) 是否在 \([B,C]\) 范围内 考虑到先将 \ ...

  5. 【赵渝强老师】使用Docker Compose进行服务编排

    一.什么是Docker Compose? Docker Compose是一个用来定义和运行复杂应用的Docker工具.一个使用Docker容器的应用,通常由多个容器组成.使用Docker Compos ...

  6. 数据库小白看这里,这个Oracle数据库知识图谱你值得拥有(含MySQL、PG图谱)

    2022年前后,墨天轮社区曾陆续推出PostgreSQL知识图谱.MySQL知识图谱,并得到了大家的广泛好评.此后,便有众多朋友对Oracle知识图谱发起不断"催更".经过近期的内 ...

  7. sqlSugar 使用原生模式链接数据库

    using System.Reflection; using zhulongxu_webapi_pro.Tools; namespace zhulongxu_webapi_pro.Services { ...

  8. js中,什么是数组 , 数组有几种创建方式?

    1. 什么是数组? 数组是可以把一组相关的数据一起存放,并提供方便的访问(存取) 数组是指一组数据的集合,其中每个数据被称作元素(数组单元),数组单元可以是任意类型的数据,数组是一种将一组数据存储在单 ...

  9. Nmap信息命令详解

    常用命令 nmap 192.168.0.100(简单扫描) nmap 192.168.0.100/24(扫描目标地址所在的某个网段) nmap 192.168.0.0/24(扫描整个子网中的网络主机信 ...

  10. Spark任务OOM问题如何解决?

    大家好,我是 V 哥.在实际的业务场景中,Spark任务出现OOM(Out of Memory) 问题通常是由于任务处理的数据量过大.资源分配不合理或者代码存在性能瓶颈等原因造成的.针对不同的业务场景 ...