vue的理解

什么是vue

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

vue的核心特性

数据驱动(MVVM)

MVVM 表示的是 Model-View-ViewModel

model:模型层,负责处理业务逻辑以及和服务器端进行交互

view:视图层,负责将数据模型转化为UI展示出来

ViewModel:视图模型层,用来连接model和view,是model和view之间的通信桥梁

组件化

什么是组件化,就是把图形,非图形的各种逻辑抽象为一个统一的概念来实现开发的模式,在vue中每一个以.vue的文件都可以被视为一个组件;

组件化的好处

降低整个系统的耦合度,可以替换不同的组件快速完成需求

调试方便,由于整个系统是通过组件组合起来的,在出现为题的时候,可以快速定位到问题,之所以能够快速定位,是因为每个组件之间低耦合,职责单一,所以逻辑会比分析整个系统要简单的多

提高可维护性,由于每个组件的职责单一,并且组件在系统中是被复用的,所以对代码进行优化可获得系统的整体升级

指令系统

指令是带有v-前缀的特殊属性,当表达式的值改变时,将其产生的连带影响,响应式的作用于DOM

常用指令

条件渲染指令:v-if

列表渲染指令:v-for

属性绑定指令:v-bind

事件绑定指令:v-on

双向数据绑定:v-model

vue于传统开发的区别:

vue的所有界面事件,都是只去操作数据的;

vue的所有界面变动,都是根据数据自动绑定出来的

vue和react对比:

相同点:

都有组件化的思想

都支持服务器端渲染

都有虚拟dom

都是数据驱动视图

都有支持native的方案:vue的weex,react的react native

都有自己的构建工具:vue的vue-cli ,react的create react app

区别:

数据流向的不同:react从诞生开始就推崇单向数据流,而vue是双向数据流

数据变化的实现原理不同:react使用的是不可变数据,而vue使用的是可变数据

组件化通信的不同:react中我们使用的是回调函数来进行通信的,而vue中子组件向父组件传递消息有两种方式:事件和回调函数

diff算法不同:react主要使用diff队列保存需要更新哪些dom,得到patch树,再统一操作批量更新dom。vue使用双向指针,边对比,边更新dom

相关推荐
吹牛不交税6 小时前
admin.net-v2 框架使用笔记-netcore8.0/10.0版
vue.js·.netcore
MZ_ZXD0017 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
_codemonster9 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
wqq631085511 小时前
Python基于Vue的实验室管理系统 django flask pycharm
vue.js·python·django
Deng94520131411 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
Hello.Reader12 小时前
Flink 文件系统通用配置默认文件系统与连接数限制实战
vue.js·flink·npm
EchoEcho14 小时前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
C澒14 小时前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
发现一只大呆瓜15 小时前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
鱼毓屿御16 小时前
如何给用户添加权限
前端·javascript·vue.js