Vue关于组件化开发知识点详解


Posted in Javascript onMay 13, 2020

全局组件注册

Vue.component('first-component', {
 data: function () {
  return {
   count: 0
  }
 },
 template: '<button @click="count++">{{ count }}</button>'
})

data 必须是一个函数

组件模板内容必须是单个根元素

组件模板内容可以是模板字符串

全局组件可以嵌套全局组件

组件命名方式

Vue.component('first-component', {/* .... */})
// 普通标签模板中不能使用驼峰, 只能在template中使用驼峰方式
Vue.component('firstComponent', {/* .... */})

局部组件注册

局部注册的组件只能在父组件中使用 ;

var vm = new Vue({
 components: {
  'hello-world': {
   data: function () {
    return {
     msg: 'hello world'
    }
   },
   template: '<div>{{ msg }}</div>'
  }
 }
})

props 传递数据原则 : 单向数据流

组件内部通过 props 接收传递过来的值

Vue.component('son-com', {
	props: ['msg', 'parentMsg']
  template: '<div>{{msg + "---" + parentMsg}}</div>'
})

父组件通过属性将值传递给子组件

<son-com msg="父组件的值" :parent-msg="bind绑定的父组件的值"></son-com>

props 属性名规则

  • 在props中使用驼峰形式, 模板中需要使用短横线的形式 ; html 对大小写的不敏感的
  • 字符串中没有这个限制

props 传递类型

<div id="app">
 <son-com
  :str="pstr"
  :num="pnum" <!-- 注意如果不用 v-bind 则获取不到准确的属性值 -->
  :boolean="pboolean"
  :arr="parr"
  :obj="pobj"
 >
 </son-com>
</div>
Vue.component('son-com', {
 props: ['str', 'num', 'boolean', 'arr', 'obj'],
 template: `
  <div>
   <div>{{ str }}</div>
   <div>{{ num }}</div>
   <div>{{ boolean }}</div>
   <ul>
    <li :key="index" v-for="(item, index) in arr">{{ item }}</li>
   </ul>
   <div>
    <span>{{ obj.name }}</span>
    <span>{{ obj.age }}</span>
   </div>
  </div>
 `
})
var vm = new Vue({
 el: '#app',
 data: {
  pstr: 'hello Vue',
  pnum: 12,
  pboolean: true,
  parr: ['apple', 'banner', 'orange'],
  pobj: {name: 'zs', age: 22}
 }
})

子组件向父组件传值

子组件通过自定义事件向父组件传值 $emit()

Vue.component('son-com', {
 template: `
  <div>
   <button @click="$emit('parent')">点击放大父组件字体</button>
   传值从第二个参数开始
	 <button @click="$emit('parent', 10)">点击放大父组件字体</button>
  </div>
 `
})

父组件监听子组件事件

<div id="app">
 <div>父组件</div>
 <son-com @parent="handle"></son-com>
 <!-- 接收值为固定 $event-->
 <son-com @parent="handle($event)"></son-com>
</div>
var vm = new Vue({
 el: '#app',
 data: {
  font: 10
 },
 methods: {
  handle: function (val) {
   this.font += 5
   this.font += val // 此时的val就是 子组件传递过来的值
  }
 },
})

非父子组件传值

单独的事件中心管理组件之间的通信

// 创建事件中心
var hub = new Vue()

// 在 mounted 中监听事件
hub.$on('eventName', fn)
hub.$off('eventName') // 销毁事件

// 在 methods 中处理事件
hub.$emit('eventName', param)

组件插槽

<tmp-com>
 <!-- 只能匹配一个标签 -->
 <p slot="header">程序错误</p>
 <div>我是没有匹配的内容</div>
 <!-- 可以匹配多个标签 -->
 <template slot="footer">
  <p>匹配页脚一次</p>
  <p>匹配页脚两次</p>
 </template>
</tmp-com>
Vue.component('tmp-com', {
 template: `
  <div>
   <header>
    <slot name="header"></slot>
   </header>
   <div>
    如果上面没有匹配到对应的标签就会展示默认内容
    <slot></slot>
   </div>
   <footer>
    <slot name="footer"></slot>
   </footer>
  </div>
 `
})

到此这篇关于Vue关于组件化开发知识点详解的文章就介绍到这了,更多相关Vue 组件化开发内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript 异步调用框架 (Part 5 - 链式实现)
Aug 04 Javascript
js 编程笔记 无名函数
Jun 28 Javascript
javascript数组的使用
Mar 28 Javascript
简介JavaScript中的unshift()方法的使用
Jun 09 Javascript
Node.js用readline模块实现输入输出
Dec 16 Javascript
JS简单实现表格排序功能示例
Dec 20 Javascript
JS随机数产生代码分享
Feb 24 Javascript
详解vue2.6插槽更新v-slot用法总结
Mar 09 Javascript
Vue拖拽组件列表实现动态页面配置功能
Jun 17 Javascript
简单学习5种处理Vue.js异常的方法
Jun 17 Javascript
JavaScript oncopy事件用法实例解析
May 13 Javascript
vue单文件组件无法获取$refs的问题
Jun 24 Javascript
Vue 中获取当前时间并实时刷新的实现代码
May 12 #Javascript
JavaScript 函数用法详解【函数定义、参数、绑定、作用域、闭包等】
May 12 #Javascript
JavaScript 面向对象程序设计详解【类的创建、实例对象、构造函数、原型等】
May 12 #Javascript
JavaScript 接口原理与用法实例详解
May 12 #Javascript
ES5新增数组的实现方法
May 12 #Javascript
JavaScript内置对象之Array的使用小结
May 12 #Javascript
详解ES6新增字符串扩张方法includes()、startsWith()、endsWith()
May 12 #Javascript
You might like
php统计文章排行示例
2014/03/04 PHP
php实现可逆加密的方法
2015/08/11 PHP
php实现的中文分词类完整实例
2017/02/06 PHP
javascript 触发HTML元素绑定的函数
2010/09/11 Javascript
javascript学习之闭包分析
2010/12/02 Javascript
js获取TreeView控件选中节点的Text和Value值的方法
2012/11/24 Javascript
jQuery 淡出一个图像到另一个图像的实现代码
2013/06/12 Javascript
js函数模拟显示桌面.scf程序示例
2014/04/20 Javascript
浅析JQuery中的html(),text(),val()区别
2014/09/01 Javascript
javascript从定义到执行 你不知道的那些事
2016/01/04 Javascript
浅析JavaScript中的变量复制、参数传递和作用域链
2016/01/13 Javascript
iScroll.js 使用方法参考
2016/05/16 Javascript
Vue.js实现在下拉列表区域外点击即可关闭下拉列表的功能(自定义下拉列表)
2017/05/30 Javascript
js实现带进度条提示的多视频上传功能
2020/12/13 Javascript
Angular事件之不同组件间传递数据的方法
2018/11/15 Javascript
Javascript Dom元素获取和添加详解
2019/09/24 Javascript
bootstrap-table后端分页功能完整实例
2020/06/01 Javascript
JavaScript原生数组函数实例汇总
2020/10/14 Javascript
Vue +WebSocket + WaveSurferJS 实现H5聊天对话交互的实例
2020/11/18 Vue.js
用Python写一个无界面的2048小游戏
2016/05/24 Python
Python有序字典简单实现方法示例
2017/09/28 Python
根据tensor的名字获取变量的值方式
2020/01/04 Python
Django-xadmin后台导入json数据及后台显示信息图标和主题更改方式
2020/03/11 Python
20行Python代码实现视频字符化功能
2020/04/13 Python
详解python中groupby函数通俗易懂
2020/05/14 Python
python switch 实现多分支选择功能
2020/12/21 Python
CSS3 简写animation
2012/05/10 HTML / CSS
美丽的珠宝配饰:SmallThings
2019/09/04 全球购物
C#面试常见问题
2013/02/25 面试题
开展批评与自我批评发言材料
2014/05/15 职场文书
大学生第一学年自我鉴定2015
2014/09/28 职场文书
2015年度绩效考核工作总结
2015/05/27 职场文书
初中毕业生感言
2015/07/31 职场文书
导游词之江南园林狮子林
2019/09/16 职场文书
深度学习小工程练习之垃圾分类详解
2021/04/14 Python
浅析Python实现DFA算法
2021/06/26 Python