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中“+=”的应用
Feb 02 Javascript
可缩放Reloaded-一个针对可缩放元素的复用组件
Mar 10 Javascript
Jquery选中或取消radio示例
Sep 29 Javascript
extJS中常用的4种Ajax异步提交方式
Mar 07 Javascript
jQuery超酷平面式时钟效果代码分享
Mar 30 Javascript
Bootstrap多级导航栏(级联导航)的实现代码
Mar 08 Javascript
JavaScript仿flash遮罩动画效果
Jun 15 Javascript
详解JS构造函数中this和return
Sep 16 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
Feb 08 Javascript
JS+HTML5实现获取手机验证码倒计时按钮
Aug 08 Javascript
vue打包相关细节整理(小结)
Sep 28 Javascript
JS实现时间校验的代码
May 25 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日历[测试通过]
2008/03/27 PHP
ThinkPHP3.1.3版本新特性概述
2014/06/19 PHP
js中将多个语句写成一个语句的两种方法小结
2007/12/08 Javascript
JavaScript中的this实例分析
2011/04/28 Javascript
getJSON调用后台json数据时函数被调用两次的原因猜想
2013/09/29 Javascript
JavaScript实现twitter puddles算法实例
2014/12/06 Javascript
jQuery基本选择器和层次选择器学习使用
2017/02/27 Javascript
javascript实现滑动解锁功能
2017/03/22 Javascript
详解vue静态资源打包中的坑与解决方案
2018/02/05 Javascript
vue父组件点击触发子组件事件的实例讲解
2018/02/08 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
vue实现轮播图帧率播放
2021/01/26 Vue.js
javascript实现简单页面倒计时
2021/03/02 Javascript
[05:43]VG.R战队教练Mikasa专访:为目标从未停止战斗
2016/08/02 DOTA
Python的Urllib库的基本使用教程
2015/04/30 Python
Python编程中用close()方法关闭文件的教程
2015/05/24 Python
使用Python脚本将文字转换为图片的实例分享
2015/08/29 Python
python下调用pytesseract识别某网站验证码的实现方法
2016/06/06 Python
python 第三方库的安装及pip的使用详解
2017/05/11 Python
Python+OpenCV人脸检测原理及示例详解
2020/10/19 Python
解决安装python库时windows error5 报错的问题
2018/10/21 Python
Python 确定多项式拟合/回归的阶数实例
2018/12/29 Python
python 实现12bit灰度图像映射到8bit显示的方法
2019/07/08 Python
详解python 利用echarts画地图(热力图)(世界地图,省市地图,区县地图)
2019/08/06 Python
python中删除某个元素的方法解析
2019/11/05 Python
python随机数分布random均匀分布实例
2019/11/27 Python
python实现密码验证合格程序的思路详解
2020/06/01 Python
Pytorch1.5.1版本安装的方法步骤
2020/12/31 Python
美国中小型企业领先的办公家具供应商:Office Designs
2016/11/26 全球购物
英国外籍人士的在线超市:British Corner Shop
2019/06/03 全球购物
2014两会学习心得:榜样精神伴我行
2014/03/17 职场文书
幼儿园毕业寄语
2014/04/03 职场文书
介绍长城的导游词
2015/01/30 职场文书
淮海战役观后感
2015/06/11 职场文书
催款函范本大全
2015/06/24 职场文书
MySQL高级进阶sql语句总结大全
2022/03/16 MySQL