Vue---自定义组件

简介: 一、组件定义       组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。

一、组件定义

       组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。在有些情况下,组件也可以表现为用is 特性进行了扩展的原生 HTML 元素。所有的 Vue 组件同时也都是 Vue 的实例,所以可接受相同的选项对象 (除了一些根级特有的选项) 并提供相同的生命周期钩子。

二、自定义组件

1、全局组件

注册全局组件:可以使用可以使用 Vue.component(tagName, options)

1 Vue.component('my-component', {
2   // 选项
3 })

组件在注册之后,便可以作为自定义元素  在一个实例的模板中使用。注意确保在初始化根实例之前注册组件:

1 <div id="example">
2   <my-component></my-component>
3 </div>

测试实例:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例 - 全局组件</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="app">
10     <!-----引用组件----->
11     <my-component></my-component>
12 </div>
13  
14 <script>
15 // 注册
16 Vue.component('my-component', {
17   template: '<h3>我是全局组件!</h3>'
18 })
19 // 创建根实例
20 new Vue({
21   el: '#app'
22 })
23 </script>
24 </body>
25 </html>

 

2、局部组件

你不必把每个组件都注册到全局。你可以通过某个 Vue 实例/组件的实例选项 components注册仅在其作用域中可用的组件: 

1 var Child = {
2 template: '<h3>我是局部组件!</h3>'
3 }new Vue({ // ... components: { // <my-component> 将只在父组件模板中可用 'my-component': Child }})

例子2:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例 - 局部组件</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="app">
10     <!-----引用组件----->
11     <my-component></my-component>
12 </div>
13  
14 <script>
15 var Child = {
16   template: '<h3>自定义组件!</h3>'
17 }
18  
19 // 创建根实例
20 new Vue({
21   el: '#app',
22   components: {
23     // <my-component> 将只在父组件模板可用
24     'my-component': Child
25   }
26 })
27 </script>
28 </body>
29 </html>

三、DOM 模板解析注意事项

   当使用 DOM 作为模板时 (例如,使用 el 选项来把 Vue 实例挂载到一个已有内容的元素上),你会受到 HTML 本身的一些限制,因为 Vue 只有在浏览器解析、规范化模板之后才能获取其内容。尤其要注意,像ul、ol、select、table这样的元素里包含的元素有限制,而另一些像option的元素只能出现在某些特定元素的内部,在自定义组建中使用这些受限制的元素,容易导致一些问题。

1 <table>
2   <my-row>...</my-row>
3 </table>

应当注意,如果使用来自以下来源之一的字符串模板,则没有这些限制:

<script type="text/x-template">
JavaScript 内联模板字符串
.vue 组件
因此,请尽可能使用字符串模板。

上面的意思是下面的例子是会不行的:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="app">
10         <select>
11             <optioncomp></optioncomp>
12         </select>
13     </div>
14  
15 <script>
16         new Vue({
17             el: '#app',
18             components:{
19                 'optioncomp':{
20                     template: '<option >a</option>'
21                 }
22             }
23         })
24     </script>
25 </body>
26 </html>

但是用is特殊属性可以:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="app">
10         <select>
11             <option is="optioncomp"></option>
12         </select>
13     </div>
14  
15 <script>
16         new Vue({
17             el: '#app',
18             components:{
19                 'optioncomp':{
20                     template: '<option >a</option>'
21                 }
22             }
23         })
24     </script>
25 </body>
26 </html>

或者temp模板标签也可以: 

 1 <body>
 2     <div id="app">
 3         <select>
 4             <option is="optioncomp"></option>
 5         </select>
 6  
 7         <!--模板内容存放区域-->
 8         <script type="x-template" id="optioncompTemp">
 9             <option >a</option>
10         </script>
11     </div>
12     
13 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
14  <script> new Vue({ el: '#app', components:{ 'optioncomp':{ template: '#optioncompTemp' } } }) </script></body>

或者内联模板字符串也行 

1 <body>
2     <div id="app">
3         <selectcomp></selectcomp>
4     </div>
5    
6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
7  <script> Vue.component('optioncomp',{ template: '<option >a</option>' }); new Vue({ el: '#app', components:{ 'selectcomp':{ template: ' <select>
8 <optioncomp></optioncomp></select>' } } }) </script></body>

data必须是函数 构造 Vue 实例时传入的各种选项大多数都可以在组件里使用。只有一个例外:data 必须是函数。实际上,如果你这么做: 

1 <code class="language-html">Vue.component('my-component', {  
2   template: '<span>{{ message }}</span>',  
3   data: {  
4     message: 'hello'  
5   }  
6 })</code>  
 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="example-2">
10   <simple-counter></simple-counter>
11   <simple-counter></simple-counter>
12   <simple-counter></simple-counter>
13 </div>
14  
15 <script>
16 var data = {counter:0};
17     Vue.component('simple-counter',{
18         template:'<button v-on:click="counter+=1">{{counter}}</button>',
19         data:function(){
20             return data;
21         }
22     })
23     new Vue({
24         el: '#example-2'
25     })
26 </script>
27 </body>
28 </html>

由于这三个组件实例共享了同一个 data 对象,因此递增一个 counter 会影响所有组件!这就错了。我们可以通过为每个组件返回全新的数据对象来修复这个问题:

1 data: function () {
2   return {
3     counter: 0
4   }
5 }

 

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>Vue 测试实例</title>
 6 <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
 7 </head>
 8 <body>
 9 <div id="example-2">
10   <simple-counter></simple-counter>
11   <simple-counter></simple-counter>
12   <simple-counter></simple-counter>
13 </div>
14  
15 <script>
16  
17     Vue.component('simple-counter',{
18         template:'<button v-on:click="counter+=1">{{counter}}</button>',
19         data: function () {
20              return {
21              counter: 0
22               }
23 }
24     })
25     new Vue({
26         el: '#example-2'
27     })
28 </script>
29 </body>
30 </html>

 

相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
3天前
|
JavaScript
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
这篇文章介绍了在Vue项目中如何实现执行删除等危险操作时的二次确认机制,使用Element UI的`el-popconfirm`组件来弹出确认框,确保用户在二次确认后才会执行删除操作。
Vue中如何设置在执行删除等危险操作时给用户提示(二次确认后执行对应的操作)
|
3天前
|
JavaScript
如何创建一个Vue项目(手把手教你)
这篇文章是一篇手把手教读者如何创建Vue项目的教程,包括使用管理员身份打开命令行窗口、找到存放项目的位置、通过vue-cli初始化项目、填写项目信息、进入项目目录、启动项目等步骤,并提供了一些常见第三方库的引入方法。
如何创建一个Vue项目(手把手教你)
|
3天前
|
JavaScript
如何在Vue页面中引入img下的图片作为背景图。../的使用
这篇文章介绍了在Vue页面中如何引入`img`目录下的图片作为背景图,提供了两种使用相对路径的方法。第一种是使用`../assets/img/`作为路径引入图片,第二种是使用`../../assets/img/`作为路径。文章还展示了使用这些方法的代码实现和效果展示,并鼓励读者学无止境。
如何在Vue页面中引入img下的图片作为背景图。../的使用
|
3天前
|
JavaScript
如何查看Vue使用的版本
这篇文章介绍了如何在项目中查看Vue及其相关库的版本信息,比如element-ui和element-china-area-data。要查看Vue的版本,需要查看项目中的`package.json`文件,在`dependencies`部分可以找到Vue的版本号。如果需要查询不同版本的兼容性,可以访问相应的官方文档或资源网站。
|
3天前
|
存储 JavaScript 前端开发
Vue中如何通过三元运算符来展示不同的操作
这篇文章讲述了在Vue中如何使用三元运算符结合v-if指令来根据订单的不同状态展示不同的操作按钮,例如在待发货状态显示退款按钮,在待付款或完成状态显示删除按钮。
|
JavaScript
Vue自定义组件事件传递:EventBus部分
组件化应用构建是Vue的特点之一,因此我们在Vue的实际开发过程中会经常需要封装自定义组件,以提高开发的效率。 而组件在大部分情况下并不会孤立的存在,它必然会与父组件和兄弟组件产生数据的交互。所以在这里为大家总结两种组件数据交互的方式:EventBus和利用Vuex框架进行状态管理。
2194 0
|
3天前
|
前端开发
StringBoot+Vue实现游客或用户未登录系统前、可以浏览商品等信息、但是不能购买商品或者加入购物车等操作。登录系统显示用户的登录名(源码+讲解)
这篇文章介绍了使用StringBoot+Vue实现用户登录状态判断的方法,包括前端加载用户信息和后端设置session的源码示例。
|
3天前
|
JavaScript 编译器
成功解决:Module build failed: Error: Vue packages version mismatch
这篇文章记录了解决Vue项目中遇到的"Module build failed: Error: Vue packages version mismatch"错误的步骤,原因是项目中Vue依赖的版本不一致,解决方法是删除`node_modules`后重新安装指定版本的Vue和`vue-template-compiler`,确保版本匹配,最终成功运行项目。
成功解决:Module build failed: Error: Vue packages version mismatch
|
3天前
|
JavaScript
在Vue中使用Avue、配置过程以及实际应用
这篇文章介绍了作者在Vue项目中集成Avue组件库的完整过程,包括安装、配置和实际应用,展示了如何利用Avue实现动态表单和数据展示的功能。
在Vue中使用Avue、配置过程以及实际应用
|
3天前
|
JavaScript
Vue devDependencies 与 dependencies 能别
Vue devDependencies 与 dependencies 能别
10 3