谷粒商城实战笔记-36-前端基础-Vue-介绍&HelloWorld

这一节的主要内容是演示Vue的简单使用。

一,MVVM 思想

  • M:即 Model,模型,包括数据和一些基本操作
  • V:即 View,视图,页面渲染结果
  • VM:即 View-Model,模型与视图间的双向操作(无需开发人员干涉)

在 MVVM 之前,开发人员从后端获取需要的数据模型,然后要通过 DOM 操作 Model 渲染到 View 中。

当视图改变后,我们还需要通过 DOM 获取 View 中的数据,然后同步到Model 中。

MVVM 中的 VM 要做的事情就是把 DOM 操作完全封装起来,开发人员不用再关心 Model 和 View 之间是如何互相影响的:

  • 只要我们 Model 发生了改变,View 上自然就会表现出来。
  • 当用户修改了 View,Model 中的数据也会跟着改变。

把开发人员从繁琐的 DOM 操作中解放出来,把关注点放在如何操作 Model 上。

直接操作DOM的示例

假设我们有一个简单的计数器应用,我们希望每次点击按钮时,页面上显示的数字增加1。

<!-- index.html -->
<div id="app">
    <p>Count: <span id="count">0</span></p>
    <button id="increment">Increment</button>
</div>

<script>
    document.getElementById('increment').addEventListener('click', function () {
        var countElement = document.getElementById('count');
        var currentCount = parseInt(countElement.textContent, 10);
        countElement.textContent = currentCount + 1;
    });
</script>

在这个例子中,直接通过getElementById获取DOM元素,并在事件处理器中修改这些元素的内容。虽然这种方法简单直观,但在复杂的用户界面和状态管理中,它容易导致代码冗长且难以维护。

使用Vue和MVVM的示例

同样的计数器应用,使用Vue框架和MVVM模式,代码看起来会更简洁且易于理解:

<!-- index.html -->
<div id="app">
    <p>Count: {{ count }}</p>
    <button @click="increment">Increment</button>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
<script>
    new Vue({
        el: '#app',
        data: {
            count: 0
        },
        methods: {
            increment: function () {
                this.count++;
            }
        }
    });
</script>

在这个Vue版本的示例中,不再直接操作DOM,而是通过定义data属性和methods来描述应用的状态和行为。Vue框架负责监听状态变化并自动更新视图,这使得代码更加简洁,逻辑更加清晰,也更容易扩展和维护。

MVVM与DOM操作的主要区别

  1. 数据绑定:在MVVM模式下,数据和视图之间是双向绑定的,数据的更改会自动反映在视图上,反之亦然。而在直接操作DOM的情况下,你需要手动更新DOM以反映数据的变化。

  2. 代码结构:MVVM模式鼓励将数据、逻辑和视图分开,这使得代码更加模块化和可测试。直接操作DOM往往会导致代码混合在一起,增加理解和维护的难度。

  3. 性能优化:Vue等MVVM框架通常会缓存和批处理DOM更新,从而提高性能。直接操作DOM可能需要更多的CPU资源,尤其是在频繁更新DOM的情况下。

综上所述,虽然直接操作DOM在某些简单场景下可能是合适的,但在构建复杂和动态的Web应用时,MVVM模式和Vue这样的框架提供了更高效、更优雅的解决方案。

二,Vue 简介

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

总之,Vue能简化前端开发,提升开发效率。

官网:https://cn.vuejs.org/
参考:https://cn.vuejs.org/v2/guide/
Git 地址:https://github.com/vuejs

三,第一个Vue项目

1 新建项目

新建文件夹vue2并在vscode中打开,因为我们要使用npm对前端工程进行管理,所以使用下面的命令初始化项目:

npm init -y

初始化完成后,在工程根目录下会自动生成一个文件package.json

在这里插入图片描述

2 安装依赖

执行如下命令安装vue依赖。

npm install vue@^2

安装完成后,会在工程根目录下多出一个node_modules的文件夹。

在这里插入图片描述

packag.json文件中新增了关于vue的依赖声明。

在这里插入图片描述

3 使用Vue

第一步,在工程根目录下,创建index.html文件。

在这里插入图片描述

第二步,引入vue。

<script src="./node_modules/vue/dist/vue.js"></script>

第三步,创建一个简单的view。

<div id="app">
   <h1>{{name}},非常帅</h1>
</div>
  • <div id="app">:这是一个普通的HTML <div> 元素,用作Vue应用的根元素。Vue实例将挂载到这个元素上。
  • <h1>{{name}},非常帅</h1>:这是一个标题元素,其中包含一个插值表达式 {{name}}插值表达式是Vue中用于数据绑定的一种方式,它允许你将数据模型中的值渲染到DOM中。

插值表达式 {{name}}

  • {{ }} 是Vue的插值语法,用于将变量的值插值到模板中。
  • name 是一个变量名,它代表Vue实例中的数据属性。在这个例子中,name 应该是一个在Vue实例中定义的属性。

第四步,在script标签中创建Vue实例

JavaScript中创建一个Vue实例,并将其挂载到具有 id="app" 的元素上。

     new Vue({
       el: '#app',
       data: {
         name: '张二强'
       }
     });

  • el 属性指定了Vue实例应该挂载的元素。
  • data 属性是一个对象,定义了Vue实例的数据属性。在这个例子中,name 是一个数据属性,它的值将被渲染到模板中。

渲染结果

在这里插入图片描述

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <h1>{{name}},非常帅</h1>
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script>
      let vm = new Vue({
        el: '#app',
        data: {
          name: "张二强"
        }
      })
    </script>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小手追梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值