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

相关推荐
lemon_yyds3 小时前
《vue 2 升级vue3 父组件 子组件 传值: value 和 v-model
vue.js
simple_lau3 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生3 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
wuhen_n6 小时前
Pinia状态管理原理:从响应式核心到源码实现
前端·javascript·vue.js
wuhen_n7 小时前
KeepAlive:组件缓存实现深度解析
前端·javascript·vue.js
wuhen_n7 小时前
Vue Router与响应式系统的集成
前端·javascript·vue.js
Ruihong7 小时前
《VuReact:下一代 Vue 3 -> React 智能编译工具,支持 SFC 与增量迁移》
vue.js
lemon_yyds7 小时前
vue 2 升级vue3 : ref 和 v-model 命名为同名
前端·vue.js
前端Hardy10 小时前
告别 !important:现代 CSS 层叠控制指南,90% 的样式冲突其实不用它也能解
前端·vue.js·面试
前端Hardy10 小时前
Vue 3 性能优化的 5 个隐藏技巧,第 4 个连老手都未必知道
前端·vue.js·面试