标签导航:

这次给大家带来vue怎么写组件,vue写组件的注意事项有哪些,下面就是实战案例,一起来看一下。

写一个vue组件

我下面写的是以.vue结尾的单文件组件的写法,是基于webpack构建的项目。如果还不知道怎么用webpack构建一个vue的工程的,可以移步到vue-cli。

一个完整的vue组件会包括一下三个部分:

  1. template:模板

  2. js: 逻辑

  3. css : 样式

每个组件都有属于自己的模板,js和样式。如果将一个页面比喻成一间房子的话,组件就是房子里的客厅、卧室、厨房、厕所。如果把厨房单独拿出来的话,组件又可以是刀、油烟机...等等。就是说页面是由组件构成的,而组件也可以是组件构成的。这样就可以非常的灵活,耦合性也非常的低。

先来看看一个组件在不是.vue文件内的写法:

Vue.component('simple-counter', {
 template: '<p><input></p>',
 data () {   // 数据
 return {
  counter: 0
 }
 },
 methods: {
 // 写点方法
 },
 created () {
 // 生命钩子
 },
 computed: {
 // 计算属性
 }
})

template是用来干嘛的呢?

<template>
 <p>
 <input>
 </p>
</template><!--
template就是这个组件的html,也就是下面部分(vue-loader会将template标签下的内容解析出来):
--><p>
 <input></p>
<!--
 对应原生写法的话,就是template内的dom字符串
-->

js部分

export default {
 data () {
 return {
  counter: 0
 }
 },
 methods: {
 // 方法
 },
 created () {
 // 生命钩子
 },
 computed: {
 // 计算属性
 }
}
// 在这里很明显js部分就是对应的原生写法内的非template部分了。
// export default这个是es6的模块写法,不懂的可以先去了解es6的模块化

css部分

<style>
...样式
</style>

引入

要怎么在其它组件引用该组件?

组件一(button.vue)

<template>
 <p>
 <button>{{text}}</button>
 </p>
</template><script>
export default {
 props: [&#39;text&#39;],   // 获取父组件的传值
 data () {
 return {
 }
 },
 methods: {
 onClick () {
  console.log(&#39;点击了子组件&#39;)
 }
 }
}
</script><style>
.button {
 button {
 width: 100px;
 }
}
</style>

组件二(box.vue)

<template>
 <p>
 <v-button></v-button>    <!--使用组件并传值(text)-->
 </p>
</template><script>
import Button from &#39;./button.vue&#39;  // 引入子组件
export default {
 components: {
 &#39;v-button&#39;: Button
 },
 data () {
 return {
  text: &#39;按键的name&#39;
 }
 },
 methods: {
 }
}
</script>

推荐阅读:

webpack热刷新与热加载使用详解

code spliting优化Vue打包步骤详解