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 迁移目录
Dec 18 Javascript
jQuery动态改变图片显示大小(修改版)的实现思路及代码
Dec 24 Javascript
一个jquery实现的不错的多行文字图片滚动效果
Sep 28 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
Jun 24 Javascript
vue开发心得和技巧分享
Oct 27 Javascript
angularjs $http实现form表单提交示例
Jun 09 Javascript
微信小程序学习之数据处理详解
Jul 05 Javascript
JS数组操作之增删改查的简单实现
Aug 21 Javascript
微信小程序 setData 对 data数据影响问题
Apr 18 Javascript
vue的keep-alive用法技巧
Aug 15 Javascript
JS实现旋转木马轮播图
Jan 01 Javascript
利用promise及参数解构封装ajax请求的方法
Mar 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 CURL模拟GET及POST函数代码
2010/04/25 PHP
PHP四舍五入精确小数位及取整
2014/01/14 PHP
php弹出对话框实现重定向代码
2014/01/23 PHP
用php守护另一个php进程的例子
2015/02/13 PHP
PHP模板引擎Smarty中的保留变量用法分析
2016/04/11 PHP
PHP7新特性之抽象语法树(AST)带来的变化详解
2018/07/17 PHP
PHP登录验证功能示例【用户名、密码、验证码、数据库、已登陆验证、自动登录和注销登录等】
2019/02/25 PHP
Js获取事件对象代码
2010/08/05 Javascript
Javascript中定义方法的另类写法(批量定义js对象的方法)
2011/02/25 Javascript
jquery文本框中的事件应用以输入邮箱为例
2014/05/06 Javascript
JavaScript获取网页、浏览器、屏幕高度和宽度汇总
2014/12/18 Javascript
JQuery fileupload插件实现文件上传功能
2016/03/18 Javascript
浅谈jquery的html方法里包含特殊字符的处理
2016/11/30 Javascript
浅析JavaScript中的平稳退化(graceful degradation)
2017/07/24 Javascript
Node.js服务器开启Gzip压缩教程
2017/08/11 Javascript
vue给对象动态添加属性和值的实例
2019/09/09 Javascript
vue从零实现一个消息通知组件的方法详解
2020/03/16 Javascript
python如何实现excel数据添加到mongodb
2015/07/30 Python
python实现按任意键继续执行程序
2016/12/30 Python
django定期执行任务(实例讲解)
2017/11/03 Python
python代码实现ID3决策树算法
2017/12/20 Python
Python:type、object、class与内置类型实例
2019/12/25 Python
HTML5 3D旋转相册的实现示例
2019/12/03 HTML / CSS
New Balance澳大利亚官网:运动鞋和健身服装
2019/02/23 全球购物
区域总监的岗位职责
2013/11/21 职场文书
生产部统计员岗位职责
2014/01/05 职场文书
弘扬雷锋精神活动演讲稿
2014/03/04 职场文书
李敖北大演讲稿
2014/05/24 职场文书
生产操作工岗位职责
2014/09/16 职场文书
奖学金个人总结
2015/03/04 职场文书
2015重阳节敬老活动总结
2015/07/29 职场文书
2016年法制宣传月活动总结
2016/04/01 职场文书
创业计划书之面包店
2019/09/12 职场文书
浅谈pytorch中stack和cat的及to_tensor的坑
2021/05/20 Python
Go语言空白表示符_的实例用法
2021/07/04 Golang
js前端设计模式优化50%表单校验代码示例
2022/06/21 Javascript