欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue单文件组件开发实现过程详解

程序员文章站 2022-08-06 17:14:09
第一步:配置环境安装cnpmnpm install -g cnpm --registry=https://registry.npm.taobao.org安装@vue/clicnpm install -...

第一步:配置环境

安装cnpm

npm install -g cnpm --registry=https://registry.npm.taobao.org

安装@vue/cli

cnpm install -g @vue/cli

检查版本是否正确

vue --version

Vue单文件组件开发实现过程详解

使用vue.server和vue.build对*.vue文件进行快速原型开发,需要安装vue serve

cnpm install -g @vue/cli-service-global

新建一个app.vue文件测试安装是否成功:

<template>2 <h1>hello world!</h1>3 </template>

在该文件当前路径运行:

vue serve app.vue

打开浏览器输入localhost:8080看到如下画面则运行成功

Vue单文件组件开发实现过程详解

环境安装到此结束,接下来用一个简单案例来学习vue的单文件组件开发。

第二步:简单案例实战

以一个物品清单为例:

Vue单文件组件开发实现过程详解

该案例由4个组件构成,分别是:

1. additem.vue 添加物品

2. item.vue 物品实例

3. items.vue 物品列表

4. changetitle 改变标题

首先,创建一个项目demo:

vue create demo

项目默认目录如下,启动主页在public, vue源码(包括组件)都存放到src

Vue单文件组件开发实现过程详解

然后分别编写各组件代码

1. additem.vue:

<template>
  <div class="input-group">
    <input type="text" class="form-control" placeholder="add shopping list item" v-model="newitem">
    <span class="input-group-btn">
      <button class="btn btn-primary" @click="emitadd">
        <i class="fa fa-plus-square-o fa-lg"> </i><span>add</span>
      </button>
    </span>
  </div>
</template>

<script>
export default {
  data() {
    return {
      newitem: ''
    }
  },
  methods: {
    emitadd() {
      this.$emit('additem', this.newitem);
    }
  }
}
</script>

<style>
</style>

2. item.vue:

<template>
  <li :class="{'removed': item.checked}" class="list-group-item">
    <div class="checkbox">
      <label>
        <input type="checkbox" v-model="item.checked">
        <span>{{ item.text }}</span>
      </label>
    </div>
  </li>
</template>

<script>
export default {
  props: ['item']
}
</script>

<style>
.removed {
  color: gray;
}

.removed span {
  text-decoration: line-through;
}
</style>

3. items.vue:

<script>
import item from './item'

export default {
  props: ['items'],
  components: {
    item
  }
}
</script>

<template>
  <ul class="list-group">
    <item v-for="item in items" :key="item.id" :item="item"></item>
  </ul>
</template>

<style>
</style>

4. changetitle.vue:

<template>
  <div>
    <em>change the title here:</em>
    <input type="text" :value="title" @input="oninput">
  </div>
</template>

<script>
export default {
  props: ['title'],
  methods: {
    oninput(event) {
      this.$emit('input', event.target.value);
    }
  }
}
</script>

最后修改app.vue,导入上面的组件:

<template>
  <div id="app" class="container">
    <h1>{{ title }}</h1>
    <add-item @additem="add"></add-item><br>
    <items :items="items"></items>
    <div class="footer">
      <hr>
      <change-title :title="title" v-model="title"></change-title>
    </div>
  </div>
</template>

<script>
import additem from './components/additem'
import items from './components/items'
import changetitle from './components/changetitle'

export default {
  name: 'app',
  components: {
    additem,
    items,
    changetitle
  },
  data() {
    return {
      items: [
        {id: 1, text: 'bananas', checked: true},
        {id: 2, text: 'apples', checked: false}
      ],
      title: 'my items list'
    }
  },
  methods: {
    add(text) {
      this.items.push({
        text: text,
        checked: false
      });
    }
  }
}
</script>

<style>
</style>

需要注意的是:每个组件必须只有一个根元素。我这里需要在public/index.html引入bootstrap样式和font-awesome图标字体。

运行程序:

cnpm run serve

最后附上运行截图:

Vue单文件组件开发实现过程详解

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。