0
点赞
收藏
分享

微信扫一扫

10天从入门到精通Vue(三)vue组件指南

@[toc]

定义Vue组件

什么是组件: 组件的出现,就是为了拆分Vue实例的代码量的,能够让我们以不同的组件,来划分不同的功能模块,将来我们需要什么样的功能,就可以去调用对应的组件即可;
组件化和模块化的不同:

  • 模块化: 是从代码逻辑的角度进行划分的;方便代码分层开发,保证每个功能模块的职能单一;
  • 组件化: 是从UI界面的角度进行划分的;前端的组件化,方便UI组件的重用;

    全局组件定义的三种方式

  1. 使用 Vue.extend 配合 Vue.component 方法:

    var login = Vue.extend({
    template: '登录'
    });
    Vue.component('login', login);
  2. 直接使用 Vue.component 方法:

    Vue.component('register', {
    template: '注册'
    });
  3. 将模板字符串,定义到script标签种:
    <script id="tmpl" type="x-template">
    <div><a rel="nofollow" href="#">登录</a> | <a rel="nofollow" href="#">注册</a></div>
    </script>

    同时,需要使用 Vue.component 来定义组件:

    Vue.component('account', {
    template: '#tmpl'
    });

    注意: 组件中的DOM结构,有且只能有唯一的根元素(Root Element)来进行包裹!

组件中展示数据和响应事件

  1. 在组件中,data需要被定义为一个方法,例如:

    Vue.component('account', {
      template: '#tmpl',
      data() {
        return {
          msg: '大家好!'
        }
      },
      methods:{
        login(){
          alert('点击了登录按钮');
        }
      }
    });
  2. 在子组件中,如果将模板字符串,定义到了script标签中,那么,要访问子组件身上的data属性中的值,需要使用this来访问;

    为什么组件中的data属性必须定义为一个方法并返回一个对象

  3. 通过计数器案例
    
    <!DOCTYPE html>
    <html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="../lib/vue-2.4.0.js"></script>
</head>

<body>
<div id="app">
<counter></counter>
</div>

<template id="tmpl">
<div>
<input type="button" @click="increase" value="+1">
<input type="button" @click="reduce" value="-1">
<h2>{{num}}</h2>
</div>
</template>

<script>
var obj = {num:0}
// 这是一个计数器的组件, 身上有个按钮,每当点击按钮,让 data 中的 count 值 +1
Vue.component('counter', {
template: '#tmpl',
data: function () {
return {num:0}
},
methods: {
increase(){
this.num++
},
reduce(){
this.num--
}
}
})

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
  el: '#app',
  data: {},
  methods: {}
});

</script>
</body>

</html>

效果如下:
![hitPlane.gif](https://s2.51cto.com/images/blog/202208/20102850_630046e241e704094.gif?x-oss-process=image/watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_30,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=)
### 使用`components`属性定义局部子组件

1. 组件实例定义方式:
```vue
<script>
  // 创建 Vue 实例,得到 ViewModel
  var vm = new Vue({
    el: '#app',
    data: {},
    methods: {},
    components: { // 定义子组件
      account: { // account 组件
        template: '<div>这是Account组件{{name}}<login></login></div>', // 在这里使用定义的子组件
        components: { // 定义子组件的子组件
          login: { // login 组件
            template: "<h3>这是登录组件</h3>"
          }
        }
      }
    }
  });
  </script>
  1. 引用组件:
    <div id="app">
    <account></account>
    </div>

本文内容到此结束了,
如有收获欢迎点赞👍收藏💖关注✔️,您的鼓励是我最大的动力。
如有错误❌疑问💬欢迎各位大佬指出。
主页:共饮一杯无的博客汇总👨‍💻

保持热爱,奔赴下一场山海。🏃🏃🏃

a37032f76d3ebe77e3e3d265ff1e1d7.jpg

举报

相关推荐

Vue从入门到精通

0 条评论