Vue.js 2 项目实战(一):图片切换案例

前言

Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架。它的设计目标是通过采用易于上手的结构和强大的功能,使前端开发变得更加简便和高效。以下是 Vue.js 的一些关键特性和优点:

核心特性

  1. 声明式渲染

    • Vue.js 使用声明式语法来描述用户界面,数据和视图是双向绑定的。当数据变化时,视图会自动更新。
  2. 组件系统

    • Vue.js 提供了一个灵活的组件系统,允许开发者将 UI 分解成可复用的组件,每个组件都有自己的逻辑和样式。
  3. 单文件组件 (SFC)

    • Vue.js 允许开发者将 HTML、CSS 和 JavaScript 放在同一个 .vue 文件中,这样可以更容易地管理组件。
  4. 虚拟 DOM

    • Vue.js 使用虚拟 DOM 来优化更新过程,通过最小化实际 DOM 操作来提高性能。
  5. 反应式数据绑定

    • Vue.js 提供了响应式的数据绑定系统,使得数据与 DOM 之间的同步变得简单和高效。
  6. 指令

    • Vue.js 提供了一组内置指令(如 v-bindv-modelv-for),帮助开发者轻松地操作 DOM。

优点

  1. 易于上手

    • Vue.js 的学习曲线较低,适合新手入门,并且文档详细、社区活跃。
  2. 灵活性

    • Vue.js 可以与现有项目集成,也可以用于构建复杂的单页面应用(SPA)。
  3. 性能高效

    • 得益于虚拟 DOM 和响应式系统,Vue.js 在处理大量数据更新时表现出色。
  4. 生态系统

    • Vue.js 拥有丰富的生态系统,包括 Vue Router、Vuex、Vue CLI 等工具和库,支持开发者在不同场景下使用。
  5. 强大的社区支持

    • Vue.js 有一个全球活跃的社区,提供了大量的插件、教程和支持资源。

知识点

1. 创建 Vue 实例

2. v-bind 数据绑定

3. @click 点击事件绑定

4. v-show 显示或隐藏元素

 项目效果

第一页

中间

最后一页

源代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
    <title>Document</title>
</head>
<body>
    <div id="app">
        <div>
            <!-- :src 是 Vue 的绑定属性语法( v-bind 的缩写),它将 img 标签的 src 属性绑定到 list[index] 的值上 -->
            <img :src="list[index]" alt="">
        </div>
        <!-- @click 是 Vue 的事件绑定语法( v-on 的缩写),当按钮被点击时,会执行 index++/index-- 操作,即将 index 增加 1/减少 1 -->
        <!-- v-show 指令用于根据条件显示或隐藏元素 -->
        <button @click="index++" v-show="index < 4">下一页</button>
        <button @click="index--" v-show="index > 0">上一页</button>
    </div>
</body>
    <script>
        const app = new Vue({
            // el: '#app' 表示将 Vue 实例挂载到 HTML 页面中的一个 DOM 元素上
            el: '#app',
            // data: {} 是一个对象,包含了 Vue 实例的初始数据状态
            data: {
                // 指定起始页图片
                index: 0,
                // 图片以列表形式存放
                list: [
                    './static/img/Advanced Mathematics.jpg',
                    './static/img/CTF.jpg',
                    './static/img/Hacker-1.jpg',
                    './static/img/Handsome.jpg',
                    './static/img/Network.jpg'
                ]
            }
        })
    </script>
</html>

相关推荐

  1. Vue2-案例tab切换栏高亮

    2024-07-22 00:18:02       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-22 00:18:02       169 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-22 00:18:02       185 阅读
  3. 在Django里面运行非项目文件

    2024-07-22 00:18:02       155 阅读
  4. Python语言-面向对象

    2024-07-22 00:18:02       169 阅读

热门阅读

  1. 《C++并发编程实战》笔记(三)

    2024-07-22 00:18:02       43 阅读
  2. 决策树:简单而强大的机器学习算法

    2024-07-22 00:18:02       42 阅读
  3. 过拟合和欠拟合的解决办法

    2024-07-22 00:18:02       37 阅读
  4. mac电脑显示隐藏文件

    2024-07-22 00:18:02       41 阅读
  5. 十、继承

    2024-07-22 00:18:02       31 阅读
  6. Dubbo 的服务降级

    2024-07-22 00:18:02       40 阅读
  7. iOS 语言基础&初探 Xcode 工具

    2024-07-22 00:18:02       38 阅读
  8. python编程技巧——list计算

    2024-07-22 00:18:02       39 阅读
  9. C语言用顺序表实现二叉树

    2024-07-22 00:18:02       36 阅读
  10. AQS源码

    2024-07-22 00:18:02       36 阅读
  11. 嵌入式软件工作能力

    2024-07-22 00:18:02       31 阅读