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. 不升级 POI 版本,如何生成符合新版标准的Excel 2007文件

    开心一刻 记得小时候,家里丢了钱,是我拿的,可爸妈却一口咬定是弟弟拿的 爸爸把弟弟打的遍体鳞伤,弟弟气愤的斜视着我 我不敢直视弟弟,目光转向爸爸说到:爸爸,你看他,好像还不服 问题描述 项目基于 PO ...

  2. manim边学边做--通用多边形

    manim提供了通用多边形模块,可以绘制任意的多边形. 通用多边形模块有两种,Polygon和Polygram. Polygon是一个几何学术语,主要指的是由三条或三条以上的线段首尾顺次连接所组成的平 ...

  3. 《你必须掌握的Entity Framework 6.x与Core 2.0》代码下载

      https://item.jd.com/12376014.html<你必须掌握的Entity Framework 6.x与Core 2.0>代码下载,共享代码: https://git ...

  4. springboot起步依赖

    <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot ...

  5. nodejs 和 npm 版本对应关系

    一.nodejs 和 npm 的版本是有适配的 首先看下官网列明的大概匹配关系: 官网链接地址:https://nodejs.org/zh-cn/about/previous-releases 可以查 ...

  6. JOI Open 2016

    T1 JOIRIS 你在玩俄罗斯方块,游戏区域是一个宽度为 \(n\),高度足够大的矩形网格.初始时第 \(i\) 列有 \(a_i\) 个方块. 给定参数 \(k\),你可以做不超过 \(10^4\ ...

  7. 云原生周刊:Kubernetes v1.31 中的移除和主要变更|2024.7.22

    开源项目 Argo Rollouts Argo Rollouts 是一个 Kubernetes 控制器和一组自定义资源定义(CRDs),提供高级部署功能,例如蓝绿部署.金丝雀部署.金丝雀分析.实验以及 ...

  8. Linux 7安装Mysql5.7版本

    Mysql 5.7的安装搭建 首先去到官方网站的下载链接中找到对应你Linux服务器版本的mysql软件包 https://dev.mysql.com/downloads/repo/yum/ 我使用的 ...

  9. 你为什么不应该过度关注go语言的逃逸分析

    逃逸分析算是go语言的特色之一,编译器自动分析变量/内存应该分配在栈上还是堆上,程序员不需要主动关心这些事情,保证了内存安全的同时也减轻了程序员的负担. 然而这个"减轻负担"的特性 ...

  10. Machine Learning Week_1 Parameter Learning 1-6

    目录 3 Parameter Learning 3.1 Video: Gradient Descent unfamiliar words 3.2 Reading:Gradient Descent un ...