<p style="text-align: left"><style type="text/css">
.btn-demo {
-webkit-Box-sizing: border-Box;
-moz-Box-sizing: border-Box;
Box-sizing: border-Box;
background-color: #19b586;
text-decoration: none;
border: none;
border-radius: 4px;
color: #fff !important;
text-decoration: none !important;
cursor: pointer;
display: inline-block;
font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
font-size: 18px;
font-weight: 700;
line-height: 1.5;
text-align: center;
text-shadow: rgba(35,69,90,0.51) 0 -1px 0;
-webkit-border-radius: 3px;
-moz-border-radius: 2px;
Box-shadow: 0 2px 2px #cddbe2;
-webkit-Box-shadow: 0 2px 2px #cddbe2;
-moz-Box-shadow: 0 2px 2px #cddbe2;
-moz-transition: opacity .2s linear;
-webkit-transition: opacity .2s linear;
-o-transition: opacity .2s linear;
margin: 10px;
padding: 5px 20px;
}
.btn-demo:hover {
background-color: #e05326;
color: #fff;
text-decoration: none;
}
概述
上一篇中我们重点介绍了组件的创建、注册和使用,熟练这几个步骤将有助于深入组件的开发。另外,在子组件中定义props,可以让父组件的数据传递下来,这就好比子组件告诉父组件:“嘿,老哥,我开通了一个驿站,你把东西放到驿站我就可以拿到了。”
今天我们将着重介绍slot和父子组件之间的访问和通信,slot是一个非常有用的东西,它相当于一个内容插槽,它是我们重用组件的基础。Vue的事件系统独立于原生的DOM事件,它用于组件之间的通信。
本文的主要内容如下:
- 组件的编译作用域
- 在组件template中使用
标签作为内容插槽 - 使用$children,$refs,$parent 实现父子组件之间的实例访问
- 在子组件中,使用$dispatch向父组件派发事件;在父组件中,使用$broadcast向子组件传播事件
- 结合这些基础知识,我们一步一步实现一个CURD的示例
Demo和源代码已放到GitHub,如果您觉得本篇内容不错,请点个赞,或在GitHub上加个星星!
注意:以下示例的组件模板都定义在标签中,然而IE不支持标签,这使得在IE中标签中的内容会显示出来。解决办法——隐藏标签
编译作用域
尽管使用组件就像使用一般的HTML元素一样,但它毕竟不是标准的HTML元素,为了让浏览器能够识别它,组件会被解析为标准的HTML片段,然后将组件的标签替换为该HTML片段。
<template id="myComponent">