Vue3初识

Vue3初识

vue.js是什么

vue是什么?官网首页就有答案:渐进式JavaScript框架。有灵活,易用,高效的特点。官网首页有详细的介绍:

v2: https://cn.vuejs.org/v2/guide/

V3:https://vuejs.org/

V3中文:https://cn.vuejs.org/

V3中文2: https://staging-cn.vuejs.org/

如何理解渐进式

个人理解:

  • 易上手,可以逐渐深入学习
  • 初创项目很简单,没有多余的东西,根据需要不断添加插件扩展项目。

相关功能有:解耦视图与数据,数据驱动,可复用的组件,前端路由,状态管理,虚拟DOM等。

与React,Angular一样,vue也是基于MVVM的一种架构模式。那么如何理解什么是MVVM呢?

MVC->MVP(省略)->MVVM

MVC

一般MVC的架构模式是前后端不分离,例如基于.net的ASP,基于java的JSP。那么为什么在MVC架构模式下开发的好好的,为什么还需要使用MVVM呢?我们用一张图来看看MVC模式做了什么。

这是MVC的一个模型图,model对应数据,view对应视图,controller对应控制器。看起来是一个很好的闭环,view->controller->model->view,逻辑清晰,易于维护,那这里面存在什么问题呢?

个人认为:

  • 前后端不分离,增加学习成本,人员问题
  • 规范的还不够严格,如果对MVC理解使用得不好可能会造成内部代码的混乱。例如多个controller对应多个model的情况,那样维护起来就有些麻烦。
  • 随着多端(桌面,h5,小程序)应用的发展,controller慢慢的不再是控制路由和逻辑,而仅仅是逻辑,作为数据接口使用,而不需要view的参与。

MVVM

那么MVVM就很好吗?它本质上就是MVC的改进版,目前来看是不错的选择。

MVVM(Model-View-ViewModel)框架的由来便是MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去,以应对客户日益复杂的需求变化。

所以,MVVM的产生由来已久。其实很多前端的一些概念,在后端早已应用,只是前端领域目前正如旭日东升,接纳百家之长而已。之前由于很多条件的限制下(带宽/客户端等),前端领域发展并不是很迅速,只需要完成简单的功能即可。随着社会的进步,人们已经不仅限于对功能的要求,还需要很好的用户体验,所以迎来了前端的春天。

插个话题

这个就像计算机语言的不断封装优化一样:

机器语言 -> 汇编-> C -> C++ ->

基于c++ 封装: C#(2000)/java(20世纪90年代)

基于c++ 解释: javascript(1995)(由于浏览器多由c++编写)

言归正传

看看mvvm的架构模式:

MVVM通过ViewModel为纽带,当view变化时,利用data binding , ViewModel会自动变化,反之亦然。

再从网上盗两张图(个人觉得还是很清晰的):

如何使用vue.js

  • 在页面上以 CDN package 的形式导入。
  • 使用 npm 安装它。
  • 使用官方的 CLI 来构建一个项目,它为现代前端工作流程提供了功能齐备的构建设置 (例如,热重载、保存时的提示等等)。

常用的就是第一种和第三种,在之后的学习中都使用第三种使用方式。

项目搭建

准备环境:

官网要求:node version >= 15

vs code

执行命令:

cmd 复制代码
npm init vue@latest

关于在新建时需要填写的选择项,在不清楚的情况下,先选择no,后期可以再添加,也可以增加印象。

初建的项目结构如下:

在刚开始的时候,只需要关注main.js,App.vue即可,所以这里把多余的文件给删除了。

注:

在项目刚创建的时候可能会因为ts, eslint等规范工具出现一些报错,解决方案如下:

https://www.jianshu.com/p/7a83c059bfc1

实例:

javascript 复制代码
<template>
  {{ msg }}
  <div>
    <h3>TO DO List</h3>
    <ul> <li v-for="item in list" :key="item">{{ item }}</li></ul>
    <input v-model="item" />
    <button @click="addItem">add</button>
    <button @click="deleteLast">delete last</button>
  </div>
</template>

<script setup lang="ts">
import { ref } from 'vue';

const msg = ref('Hello World');

const list = ref(['李白', '杜甫', '白居易']);
const item = ref('');

function addItem() {
  if (item.value) {
    list.value.push(item.value);
    item.value = '';
  }
}

const deleteLast = () => {
  list.value.length > 0 && list.value.pop();
};
</script>

<style scoped>
li {
  color: blueviolet;
}
</style>
相关推荐
533_1 小时前
[vue] 深拷贝 lodash cloneDeep
前端·javascript·vue.js
ZBY520312 小时前
【Vue】 npm install amap-js-api-loader指南
javascript·vue.js·npm
计算机毕设指导62 小时前
基于 SpringBoot 的作业管理系统【附源码】
java·vue.js·spring boot·后端·mysql·spring·intellij-idea
木子02043 小时前
前端VUE项目启动方式
前端·javascript·vue.js
运维-大白同学4 小时前
将django+vue项目发布部署到服务器
服务器·vue.js·django
星星会笑滴5 小时前
vue+node+Express+xlsx+emements-plus实现导入excel,并且将数据保存到数据库
vue.js·excel·express
Backstroke fish6 小时前
Token刷新机制
前端·javascript·vue.js·typescript·vue
临枫5416 小时前
Nuxt3封装网络请求 useFetch & $fetch
前端·javascript·vue.js·typescript
RAY_CHEN.6 小时前
vue3 pinia 中actions修改状态不生效
vue.js·typescript·npm
酷酷的威朗普6 小时前
医院绩效考核系统
javascript·css·vue.js·typescript·node.js·echarts·html5