(Vue)谈谈对 React 和 Vue的理解以及它们的异同

React 的特点:

  1. JSX: React 使用 JSX 语法,将HTML写在JavaScript代码中,使得组件的结构和逻辑更紧密地结合在一起。
  2. 灵活性: React 提供了更多的灵活性,但相对需要更多的配置和决策。它更像是一个库而不是一个完整的框架。
  3. 社区和生态系统: React 有一个庞大而活跃的社区,丰富的第三方库和工具,以及许多支持React的工具和平台。

Vue 的特点:

  1. 模板语法: Vue 使用模板语法,将HTML写在字符串模板中,更接近传统的HTML和JavaScript分离的方式。
  2. 易用性: Vue 被认为更容易上手,相对于React而言,Vue提供了更多的默认行为,减少了一些配置的需求。
  3. 渐进式框架: Vue 被设计为渐进式框架,可以逐步应用到项目中,也可以整体引入。这使得Vue在现有项目中的集成更为容易。
  4. 单文件组件: Vue 支持单文件组件,将模板、样式和逻辑封装在一个文件中,使得组件更加整洁。

异同比较:

相同之处

  • 都将注意力集中保持在核心库,而将其他功能如路由和全局状态管理交给相关的库

  • 都有自己的构建工具,能让你得到一个根据最佳实践设置的项目模板

  • 都使用了 Virtual DOM(虚拟 DOM)提高重绘性能

  • 都有 props 的概念,允许组件间的数据传递

  • 都鼓励组件化应用,将应用分拆成一个个功能明确的模块,提高复用性。

不同之处

比较点 Vue React
数据流 默认支持双向绑定 一直提倡单向数据流
虚拟DOM Vue2.x引入虚拟DOM,可以更快的计算出虚拟DOM的差异,渲染过程中会跟踪每一个组件的依赖关系,不需要重新渲染整个组件树。 每当应用的状态被改变时,全部子组件都会重新渲染。当然,这可以通过 PureComponent/shouldComponentUpdate 这个生命周期方法来进行控制,但 Vue 将此视为默认的优化。
组件化 鼓励写近似常规 HTML 的模板。写起来很接近标准 HTML 元素,只是多了一些属性。 推荐你所有的模板通用 JavaScript 的语法扩展------JSX 书写
监听数据变化的实现原理 通过 getter/setter 以及一些函数的劫持,能精确知道数据变化,不需要特别的优化就能达到很好的性能 默 认 是 通 过 比 较 引 用 的 方 式 进 行 的 , 如 果 不 优化(PureComponent/shouldComponentUpdate)可能导致大量不必要的vDOM 的重新渲染。这是因为 Vue 使用的是可变数据,而 React 更强调数据的不可变。
高阶组件 需要通过 mixins 来扩展 可以通过高阶组件(HOC)来扩展
构建工具 vue-cli Create React APP
跨平台 Weex React Native
  1. 设计理念:

    • React 更加注重灵活性和可组合性,适用于大型、复杂的项目。
    • Vue 更加注重开发者友好性和逐步增量,适用于小型、中型项目。
  2. 数据绑定:

    • React 使用单向数据流,通过 props 进行数据传递。
    • Vue 使用响应式数据绑定,数据发生变化时视图会自动更新。
  3. 模板语法:

    • React 使用 JSX,将HTML直接嵌入JavaScript代码中。
    • Vue 使用模板语法,通过指令来处理DOM操作。
  4. 学习曲线:

    • React 学习曲线较陡峭,特别是对于理解虚拟DOM和JSX的新手。
    • Vue 学习曲线较为平缓,文档清晰,适合初学者。
  5. 生态系统:

    • React 生态系统庞大,有大量的第三方库和工具支持。
    • Vue 生态系统相对较小,但也在不断发展壮大。

总体而言,选择使用 React 还是 Vue 取决于个人或团队的偏好、项目需求以及开发经验。两者都有强大的功能和庞大的社区支持,因此可以根据具体情况来做出选择。

对上面一些概念的补充

高阶组件

高阶组件就是高阶函数,而 React 的组件本身就是纯粹的函数,所以高阶函数对 React 来说易如反掌。相反 Vue.js 使用 HTML 模板创建视图组件,这时模板无法有效的编译,因此 Vue 不能采用 HOC 来实现。

最大的不同-模板编写(组件化)

React 中 render 函数是支持闭包特性的,所以 import 的组件在 render 中可以直接调用。但是在 Vue 中,由于模板中使用的数据都必须挂在 this 上进行一次中转,所以 import一个组件完了之后,还需要在 components 中再声明下

相关推荐
心.c25 分钟前
深拷贝浅拷贝
开发语言·前端·javascript·ecmascript
IT_陈寒1 小时前
Vue 3.4性能优化实战:5个鲜为人知的Composition API技巧让打包体积减少40%
前端·人工智能·后端
前端九哥1 小时前
💻【急招!27届前端实习生】广州4399实习太幸福了!江景+三餐+健身房全都有😭
前端·面试·招聘
咖啡の猫1 小时前
Vue全局事件总线
前端·javascript·vue.js
大厂码农老A1 小时前
我带的外包兄弟放弃大厂转正,薪资翻倍入职字节
java·后端·面试
Lovereo1 小时前
我的目标检测性能优化之路:预算不够、GPU 没有、但性能我得要
前端
T___T1 小时前
JavaScript 变量声明详解:var、let、const 的核心差异
javascript·面试
T___T2 小时前
Git 入门实战笔记:从 0 到 1 掌握代码版本管理流程
git·面试
蒙娜丽宁2 小时前
Rust 与 WebAssembly:构建高效前端应用的全流程复盘
前端·rust·wasm
这儿有一堆花2 小时前
使用 Actix-web 开发高性能 Web 服务
前端·数据库