Vue第1天:特性概览

简介: Vue第1天:特性概览

Vue.js 简介

Vue.js(通常简称为Vue)是一款流行的JavaScript框架,专注于构建用户界面。它的设计灵感来自于现代的JavaScript框架,同时也借鉴了一些传统的MVC模式的思想。

Vue的特性

Vue拥有许多强大的特性,使得它成为构建交互式用户界面的理想选择:

  1. 响应式数据绑定: Vue采用了双向数据绑定,通过数据驱动视图,当数据发生变化时,视图会自动更新。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue - 响应式数据绑定</title>
</head>
<body>
 
<div id="app">
    <p>{{ message }}</p>
    <input v-model="message">
</div>
 
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
<script>
    // 创建Vue实例
    var app = new Vue({
        el: '#app',
        data: {
            message: 'Hello, Vue!'
        }
    });
</script>
 
</body>
</html>
  1. 在这个例子中,v-model 指令用于实现输入框和数据的双向绑定,当输入框中的内容变化时,数据 message 也会相应地更新。
  2. 组件化开发: Vue支持组件化开发,使得UI可以被拆分为独立、可复用的组件。这种模块化的开发方式使得代码更易维护、可读性更强。
<!-- App.vue -->
<template>
  <div>
    <my-component></my-component>
    <my-component></my-component>
  </div>
</template>
 
<script>
import MyComponent from './MyComponent.vue';
 
export default {
  components: {
    'my-component': MyComponent
  }
};
</script>
 
<!-- MyComponent.vue -->
<template>
  <div>
    <p>This is a reusable component.</p>
  </div>
</template>
 
<script>
export default {
  // 组件逻辑
};
</script>
  1. 在这个例子中,App.vue 文件引入并使用了名为 my-component 的组件。而 MyComponent.vue 文件定义了一个简单的可复用组件。
  2. 指令系统: Vue提供了一系列指令(Directives),如v-bindv-ifv-for等,使得开发者可以在模板中添加逻辑、控制DOM元素的显示和隐藏等。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue - 指令系统</title>
</head>
<body>
 
<div id="app">
    <p v-if="showMessage">{{ message }}</p>
    <ul>
        <li v-for="item in items" :key="item.id">{{ item.name }}</li>
    </ul>
</div>
 
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
<script>
    // 创建Vue实例
    var app = new Vue({
        el: '#app',
        data: {
            showMessage: true,
            message: 'This message is shown with v-if',
            items: [
                { id: 1, name: 'Item 1' },
                { id: 2, name: 'Item 2' },
                { id: 3, name: 'Item 3' }
            ]
        }
    });
</script>
 
</body>
</html>
  1. 在这个例子中,v-if 用于根据条件显示或隐藏一个元素,而 v-for 用于循环渲染一个列表。
  2. 虚拟DOM: Vue通过虚拟DOM的机制,提高了DOM操作的效率,只更新实际改变的部分,而不是整个DOM树。
  3. 生命周期钩子: Vue提供了丰富的生命周期钩子函数,使得开发者可以在不同阶段插入自定义的逻辑。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue - 生命周期钩子</title>
</head>
<body>
 
<div id="app">
    <p>{{ message }}</p>
</div>
 
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
<script>
    // 创建Vue实例
    var app = new Vue({
        el: '#app',
        data: {
            message: 'Hello, Vue!'
        },
        beforeCreate() {
            console.log('beforeCreate');
        },
        created() {
            console.log('created');
        },
        beforeMount() {
            console.log('beforeMount');
        },
        mounted() {
            console.log('mounted');
        },
        beforeUpdate() {
            console.log('beforeUpdate');
        },
        updated() {
            console.log('updated');
        },
        beforeDestroy() {
            console.log('beforeDestroy');
        },
        destroyed() {
            console.log('destroyed');
        }
    });
</script>
 
</body>
</html>
  1. 在这个例子中,我们使用了 Vue 的生命周期钩子,通过在控制台输出不同阶段的信息,帮助你理解 Vue 生命周期的执行顺序。打开浏览器的开发者工具,可以在控制台中看到输出信息。

如何使用Vue

安装Vue

你可以通过CDN引入Vue,也可以使用npm进行安装。

通过CDN引入
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
使用npm
npm install vue

创建Vue实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vue Introduction</title>
</head>
<body>
 
<div id="app">
    {{ message }}
</div>
 
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
<script>
    // 创建Vue实例
    var app = new Vue({
        el: '#app',
        data: {
            message: 'Hello, Vue!'
        }
    });
</script>
 
</body>
</html>

在上述代码中,我们首先引入Vue,然后创建了一个Vue实例,并在HTML中绑定了一个数据message,最后将这个实例挂载到ID为app的DOM元素上。

结语

Vue.js的简单上手、灵活的设计和强大的特性使得它成为构建现代Web应用的理想选择。通过Vue,你可以更轻松地构建交互式、动态的用户界面。

这只是Vue.js的入门介绍,Vue还有很多其他特性和高级用法,如果你对Vue感兴趣,可以深入学习官方文档以及社区资源。

相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
5天前
|
JavaScript
vue消息订阅与发布
vue消息订阅与发布
|
2天前
|
JavaScript
理解 Vue 的 setup 应用程序钩子
【10月更文挑战第3天】`setup` 函数是 Vue 3 中的新组件选项,在组件创建前调用,作为初始化逻辑的入口。它接收 `props` 和 `context` 两个参数,内部定义的变量和函数需通过 `return` 暴露给模板。`props` 包含父组件传入的属性,`context` 包含组件上下文信息。`setup` 可替代 `beforeCreate` 和 `created` 钩子,并提供类似 `data`、`computed` 和 `methods` 的功能,支持逻辑复用和 TypeScript 类型定义。
20 11
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
14 4
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【51.路由懒加载】
vue尚品汇商城项目-day07【51.路由懒加载】
15 4
|
5天前
|
JavaScript 前端开发
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
14 2
|
5天前
|
JavaScript 前端开发 API
Vue学习笔记7:使用v-for指令渲染列表
Vue学习笔记7:使用v-for指令渲染列表
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1039 0
|
7天前
|
JavaScript
vue组件中的插槽
本文介绍了Vue中组件的插槽使用,包括单个插槽和多个具名插槽的定义及在父组件中的使用方法,展示了如何通过插槽将父组件的内容插入到子组件的指定位置。
|
6天前
|
JavaScript 前端开发 IDE
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
下一篇
无影云桌面