前端开发中的模拟后端与MVVM架构实践[特殊字符][特殊字符][特殊字符]

平时,后端可能不能及时给接口给前端进行数据调用和读取。这时候,前端想到进行模拟后端接口。本文将介绍如何通过vite-plugin-mock插件模拟后端接口,并探讨MVVM架构在前端开发中的应用。此外,我们还将讨论Vue2与Vue3的区别,以及如何处理动态路由和登录鉴权等常见问题。

一、模拟后端接口

通过模拟接口,前端开发者可以在不依赖后端的情况下进行开发和调试。

1. 使用 vite-plugin-mock 插件

vite-plugin-mock 是一个用于Vite项目的插件,可以帮助我们快速创建模拟接口。以下是使用步骤:

  1. 安装插件

    npm i vite-plugin-mock -D
    
  2. vite.config.js 中配置

    import { defineConfig } from 'vite';
    import vue from '@vitejs/plugin-vue';
    import { viteMockServe } from 'vite-plugin-mock';export default defineConfig({plugins: [vue(),viteMockServe({mockPath: 'mock', // 指定mock文件存放的目录localEnabled: true, // 开发环境启用mock}),],
    });
    
  3. 创建模拟接口
    在项目根目录下创建 mock 文件夹,并在其中创建 user.js 文件:

    export default [{url: '/api/login',method: 'post',response: () => {return {code: 200,message: 'success',data: {token: 'mock-token',},};},},
    ];
    

通过以上步骤,我们可以在开发环境中使用 /api/login 接口进行登录模拟。
在这里插入图片描述

二、MVVM架构

MVVM(Model-View-ViewModel)是一种前端架构模式,它将应用程序分为三个部分:Model、View 和 ViewModel。

1. MVVM 的核心概念

  • Model:数据模型,负责处理数据逻辑,通常包括从后端获取数据的部分(如Axios请求)。
  • View:视图层,负责展示数据和用户界面。
  • ViewModel:连接View和Model的桥梁,负责生成和维护视图与数据层的关系。它将视图的状态和行为封装在其中,使得View和Model之间的耦合度降低。

2. MVVM 的优势

  • 低耦合:MVVM架构使得View、Model和ViewModel之间的关联性减弱,各自独立,互不影响。
  • 分层开发:通过分层开发,开发者可以更好地组织代码,提高代码的可维护性和可扩展性。
    在这里插入图片描述

三、Vue2 与 Vue3 的区别

Vue3 是 Vue2 的升级版本,带来了许多新特性和改进。以下是两者之间的主要区别:

1. 双向绑定原理

  • Vue2:使用 Object.defineProperty() 实现双向绑定。这种方式在后续更新属性时无法劫持,导致数据更新时视图不更新。
  • Vue3:使用 Proxy 实现双向绑定。Proxy 可以劫持后续更新的数据,确保数据更新时视图同步更新。

2. $set 方法

  • Vue2:使用 this.$set 来动态添加响应式属性。
  • Vue3:不再需要 $set 方法,直接使用 refreactive 即可。

3. 生命周期

  • Vue2beforeCreate, created, beforeMount, mounted, beforeUpdate, updated, beforeDestroy, destroyed, activated, deactivated
  • Vue3setup, onBeforeMount, onMounted, onBeforeUpdate, onUpdated, onBeforeUnmount, onUnmounted

4. 父子组件通信

  • Vue2
    • 父传子:通过 props
    • 子传父:通过 this.$emit("事件", 参数)
  • Vue3
    • 父传子:通过 props
    • 子传父:通过 defineEmits(['事件名称'])

5. API 风格

  • Vue2:选项式API,将不同的属性(如 data, methods)分开定义。
  • Vue3:组合式API,允许将相关逻辑组织在一起,提高代码的可读性和可维护性。

6. 多根节点支持

  • Vue2:只支持单根节点。
  • Vue3:支持多根节点。

7. 数据定义

  • Vue2:在 data() 中定义数据。
  • Vue3:使用 refreactive 定义数据。

四、动态路由与登录鉴权

在后台管理系统中,动态路由和登录鉴权是常见的需求。以下是处理这些问题的常见方法:

1. 动态路由

动态路由可以根据用户的权限动态加载路由。常见的实现方式是通过 addRoute 方法动态添加路由。

  • 问题:刷新页面后,动态路由会丢失。
  • 解决方案:将路由信息存储在 localStoragesessionStorage 中,页面刷新时重新加载路由。

2. 登录鉴权

登录鉴权是确保用户访问权限的重要环节。常见的实现方式包括:

  • Token 验证:用户登录后,后端返回一个Token,前端将其存储在 localStoragecookie 中,每次请求时携带该Token进行验证。
  • 路由守卫:在路由跳转前,通过路由守卫检查用户是否已登录,未登录则跳转到登录页面。

五、项目实践

在一个使用 Vue3 + Vite + Element Plus + Pinia + Apifox 的后台管理项目中,可能会遇到以下问题:

1. 首页加载慢

  • 解决方案:使用虚拟长列表和分段加载技术,减少一次性加载的数据量,提高页面加载效率。

2. 安全性

  • 解决方案:确保Token的安全性,避免XSS攻击,使用HTTPS加密传输数据。

六、总结

通过 vite-plugin-mock 插件,我们可以轻松模拟后端接口,加快前端开发进度。MVVM架构帮助我们更好地组织代码,降低耦合度,提高代码的可维护性。Vue3 带来了许多新特性,如 Proxy 双向绑定、组合式API等,使得开发更加高效。动态路由和登录鉴权是后台管理系统中常见的需求,合理处理这些问题可以提升用户体验和系统安全性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67893.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML5 新表单属性详解

HTML5 为 <form> 和 <input> 标签引入了一系列新属性&#xff0c;极大地增强了表单的功能和用户体验。这些新属性不仅简化了开发者的工作&#xff0c;还为用户提供了更友好、更高效的交互方式。本文将详细介绍这些新属性&#xff0c;并结合代码示例帮助大家更好地理…

SuperdEye:一款基于纯Go实现的间接系统调用执行工具

关于SuperdEye SuperdEye是一款基于纯Go实现的间接系统调用执行工具&#xff0c;该工具是TartarusGate 的修订版&#xff0c;可以利用Go来实现TartarusGate 方法进行间接系统调用。 该工具的目标是为了扫描挂钩的NTDLL并检索Syscall编号&#xff0c;然后使用它来执行间接系统调…

MySQL可直接使用的查询表的列信息

文章目录 背景实现方案模板SQL如何查询列如何转大写如何获取字符位置如何拼接字段 SQL适用场景 背景 最近产品找来&#xff0c;想让帮忙出下表的信息&#xff0c;字段驼峰展示&#xff0c;每张表信息show create table全部展示&#xff0c;再逐个粘贴&#xff0c;有点太耗费时…

HMV Challenges 022 Writeup

题目地址&#xff1a;https://hackmyvm.eu/challenges/challenge.php?c022 首先猜测是否为图片隐写&#xff0c;无果 盲猜图片上的小鸟是某种带符号的隐写 去这个网站找找看&#xff1a;https://www.dcode.fr/chiffres-symboles 找到了 参照原图片鸟儿的姿态选择并排放 所…

不建模,无代码,如何构建一个3D虚拟展厅?

在数字化浪潮的推动下&#xff0c;众多企业正积极探索线上3D虚拟展厅这一新型展示平台&#xff0c;旨在以更加生动、直观的方式呈现其产品、环境与综合实力。然而&#xff0c;构建一个既专业又吸引人的3D虚拟展厅并非易事&#xff0c;它不仅需要深厚的技术支持&#xff0c;还需…

【真机调试】前端开发:移动端特殊手机型号有问题,如何在电脑上进行调试?

目录 前言一、怎么设置成开发者模式&#xff1f;二、真机调试基本步骤&#xff1f; &#x1f680;写在最后 前言 edge浏览器 edge://inspect/#devices 谷歌浏览器&#xff08;开tizi&#xff09; chrome://inspect 一、怎么设置成开发者模式&#xff1f; Android 设备 打开设…

企业分类相似度筛选实战:基于规则与向量方法的对比分析

文章目录 企业表相似类别筛选实战项目背景介绍效果展示基于规则的效果基于向量相似的效果 说明相关文章推荐 企业表相似类别筛选实战 项目背景 在当下RAG&#xff08;检索增强生成&#xff09;技术应用不断发展的背景下&#xff0c;掌握文本相似算法不仅能够助力信息检索&…

校园网上店铺的设计与实现(代码+数据库+LW)

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统校园店铺商品销售信息管理难度大&#xff0c;容错率低&a…

基于springboot+vue的校园二手物品交易系统的设计与实现

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

编译Android平台使用的FFmpeg库

目录 前言 一、编译环境 二、搭建环境 1.安装MSYS2 2.更新系统包 2.1 打开MSYS2 MinGW 64-bit终端&#xff08;mingw64.exe&#xff09; 2.2 更新所有软件包到最新版本 2.3 安装必要的工具和库。 3. 克隆FFmpeg源码 4. 配置编译选项 5. 执行编译 总结 前言 记录学习…

vim如何显示行号

:set nu 显示行号 :set nonu 不显示行号

揭开C++ 继承 的神秘面纱:深度剖析 类 的“血脉”传承

在C的面向对象编程中&#xff0c;继承&#xff08;Inheritance&#xff09;是实现代码复用和层次结构的重要特性。通过继承&#xff0c;新的类&#xff08;派生类&#xff09;可以从现有的类&#xff08;基类&#xff09;中继承属性和行为&#xff0c;从而减少重复代码&#xf…

翻译:How do I reset my FPGA?

文章目录 背景翻译&#xff1a;How do I reset my FPGA?1、Understanding the flip-flop reset behavior2、Reset methodology3、Use appropriate resets to maximize utilization4、Many options5、About the author 背景 在写博客《复位信号的同步与释放&#xff08;同步复…

基于微信小程序的设备故障报修管理系统设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

ue5 GAS制作一个技能

新建文件夹 ability 取名BP_BaseAbility 新建一个技能GAB_Melee 上面技能GAB_Melee和技能基类BP_BaseAbility 进入技能GAB_Melee&#xff0c;添加打印火云掌 给这个技能添加标签 点这个号 这样命名&#xff0c;小心这个点&#xff08;.&#xff09;作为分割 ability.ha…

PHP校园助手系统小程序

&#x1f511; 校园助手系统 —— 智慧校园生活 &#x1f4f1;一款基于ThinkPHPUniapp框架深度定制的校园助手系统&#xff0c;犹如一把智慧之钥&#xff0c;专为校园团队精心打造&#xff0c;解锁智慧校园生活的无限精彩。它独家适配微信小程序&#xff0c;无需繁琐的下载与安…

阿里云服务器突然有大量nmap服务占用大量CPU排查及解决方案

问题描述 突然有一天服务器访问很卡顿,在阿里云后台查看CPU,内存,系统平均负载等参数发现没问题 但是登陆服务器后,发现大量nmap服务占用大量CPU,但是这台管理员并没有主动安装过nmap 原因及对应预防方案 暴力破解 SSH 密码&#xff1a;通过爆破弱密码或没有加固的 SSH 配置。…

一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk

文章目录 一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk1. 建议按文章顺序从头看&#xff0c;一看到底&#xff0c;豁然开朗2. 啥是chunkIds3.怎么使用chunkIds4. 啥是runtimeChunk5. 怎么使用runtimeChunk 一文大白话讲清楚webpack基本使用——11——chun…

给工作流穿上漂亮的衣服,创建用户交互界面并调用工作流,可定制的工作流,奶奶都能看明白的扣子智能体免费系列教程(10)

创建工作流看这个 搭建小红书梗图、歪理生成器工作流搭建 效果 欢迎来到滔滔讲AI。本教程为免费系列教程&#xff0c;感谢关注&#xff0c;以防找不到。 一、新建应用 方式一&#xff0c;点击左侧导航的加号 方式二、在工作空间面板选择右上角的创建按钮 选择创建应用 二、…

2024年度总结-CSDN

2024年CSDN年度总结 Author&#xff1a;OnceDay Date&#xff1a;2025年1月21日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 文章目录 2024年CSDN年度总结1. 整体回顾2…