首发于 vue
Vue.js基础教学

Vue.js基础教学

Vue.js基础教学

Vue.js 是一款轻量级、易学的前端框架,它是用于构建用户界面的渐进式框架。在这篇教程中,我们将介绍 Vue.js 的基础概念,并通过实际示例来帮助你了解 JavaScript 语法。

在该教程的最后会完整地介绍如何搭建一个Vue地计数器工程。

1. 安装 Vue CLI

为了更好地管理项目结构和依赖,我们可以使用 Vue CLI(命令行工具)来创建一个 Vue 工程。首先,你需要 安装 Node.js ,然后使用 npm (Node.js 包管理器)全局安装 Vue CLI。在命令行中输入以下命令:

npm install -g @vue/cli

2. 创建 Vue 工程

安装完成后,你可以使用 vue create 命令来创建一个新的 Vue 工程:

vue create my-vue-app

在这个例子中, my-vue-app 是你的项目名称。命令执行后,你将看到一个交互式命令行界面,用于选择项目的预设配置。你可以选择默认的预设配置,也可以手动选择需要的特性。

3. 运行 Vue 工程

创建 Vue 工程后,进入项目文件夹:

cd my-vue-app

然后使用以下命令安装项目依赖:

npm install xxx

接下来,你可以运行以下命令启动开发服务器:

npm run serve

命令执行后,你将看到一个提示,告诉你在哪个地址和端口可以访问你的应用(通常是 http://localhost:8080/ )。现在你可以在浏览器中访问这个地址,看到你的 Vue 应用正在运行。

4. Vue 实例

在引入 Vue.js 之后,我们需要创建一个 Vue 实例。Vue 实例是一个 JavaScript 对象,它包含了应用的数据、方法等属性。以下是一个简单的 Vue 实例:

// JavaScript 对象字面量语法,用于创建一个对象
var app = new Vue({
  el: '#app', // 指定 Vue 实例挂载的元素
  data: { // 声明应用的数据
    message: 'Hello, Vue.js!'

在这个例子中,我们用一个对象字面量来创建 Vue 实例。对象字面量是用花括号 {} 包围的键值对集合。每个键值对用冒号( : )分隔,不同的键值对之间用逗号( , )分隔。

5. 数据绑定

Vue.js 提供了非常简洁的模板语法,可以方便地将数据绑定到 DOM。例如:

<div id="app">
  <h1>{{ message }}</h1>
</div>

在这个例子中,我们使用双大括号 {{ }} 作为插值表达式,将 Vue 实例的 message 属性值插入到 DOM 中。

6. 指令

Vue.js 提供了一些特殊的属性,称为指令(Directives)。指令用于在 DOM 元素上添加特殊的行为。以下是一个使用 v-bind 指令的例子:

<div id="app">
  <h1 v-bind:title="message">{{ message }}</h1>
</div>

在这个例子中,我们使用 v-bind 指令将 Vue 实例的 message 属性值绑定到 h1 元素的 title 属性上。当鼠标悬停在这个元素上时,会显示 message 的内容。

7. 事件处理

在 Vue.js 中,我们可以使用 v-on 指令来监听 DOM 事件,例如点击事件。以下是一个简单的事件处理例子:

<div id="app">
  <button v-on:click="reverseMessage">Reverse Message</button>
  <h1>{{ message }}</h1>
</div>
var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello, Vue.js!'
  methods: { // 定义 Vue 实例的方法
    reverseMessage: function () {
      // 使用 JavaScript 的字符串方法反转 message
      this.message = this.message.split('').reverse().join('');
});

在这个例子中,我们使用 v-on:click 指令监听按钮的点击事件,并在点击时调用 reverseMessage 方法。 reverseMessage 方法将 message 字符串反转。

8. 计算属性

计算属性是一种依赖其他属性的值进行计算的属性。它们是 Vue.js 提供的一种优雅的处理方式,具有缓存功能,只有当依赖的值发生变化时,计算属性才会重新计算。以下是一个简单的计算属性示例:

<div id="app">
  <h1>{{ reversedMessage }}</h1>
</div>
var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello, Vue.js!'
  computed: { // 定义计算属性
    reversedMessage: function () {
      // 使用 JavaScript 的字符串方法反转 message
      return this.message.split('').reverse().join('');
});

在这个例子中,我们使用计算属性 reversedMessage 来实现 message 的反转。与上一个例子中的方法不同,计算属性具有缓存功能,只有当 message 值发生变化时,计算属性才会重新计算。

9. 构建 Vue 工程

在开发完成后,你需要构建项目,生成可供生产环境部署的静态文件。运行以下命令:

npm run build

构建完成后,项目文件夹下会生成一个 dist 文件夹,其中包含了构建后的静态文件。你可以将这些文件部署到任何支持静态文件托管的服务器上。

10.创建一个Vue工程完整流程

在这里演示一个创建Vue工程的完整流程,作者使用的是 Vue3

现在一个文件夹中创建Vue工程,例如在vue文件夹中创建 (记得开启管理员模式)

E:\vue>vue create my-vue-app

之后你会在该文件夹底下发现一个 my-vue-app 的文件夹。

将文件夹中的一些文件进行修改,其中 components/ 文件夹只保留 MyCounter.vue 文件。

文件结构

my-vue-app/
|-- public/
|   |-- index.html
|-- src/
|   |-- components/
|       |-- MyCounter.vue
|   |-- App.vue
|   |-- main.js

修改文件

index.html

<!DOCTYPE html>
<html lang="en">
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Vue Counter App</title>
  </head>
    <div id="app"></div>
  </body>
</html>

main.js

import { createApp } from "vue";
import App from "./App.vue";
const app = createApp(App);
app.mount("#app");

App.vue

<template>
  <div id="app">
    <h1>Vue Counter App</h1>
    <MyCounter />
  </div>
</template>
<script>
import MyCounter from "./components/MyCounter.vue";
export default {
  name: "App",
  components: {
    MyCounter,
</script>
<style>
#app {
  text-align: center;
</style>

MyCounter.vue

<template>
  <div class="my-counter">
    <h2>{{ count }}</h2>
    <button @click="increment">+</button>
    <button @click="decrement">-</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      count: 0,
  methods: {
    increment() {
      this.count++;
    decrement() {
      this.count--;
</script>
<style scoped>
.my-counter {
  display: inline-block;
button {
  margin: 0 5px;
</style>

修改完后保存工程,在 .\vue\my-vue-app 底下npm run serve,例如:

E:\vue\my-vue-app>npm run serve

出现以下内容说明搭建成功:

DONE  Compiled successfully in 2671ms                                                                          17:39:34