react和vue的实现原理有什么不同?

作者&投稿:实珊 (若有异议请与网页底部的电邮联系)
Vue框架和react框架有什么不同吗?~

React 从一开始的定位就是提出 UI 开发的新思路。
当年 Pete Hunt 最开始推广 React 的时候的一句口号就叫 "Rethinking Best Practices",这样的定位使得 React 打开了一些全新的思路,吸引了一群喜欢折腾的早期核心用户,并在这个基础上通过社区迭代孵化出了许多今天被 React 开发者当作常识的 pattern。
这是 React 伟大的地方,Vue 里面也有很多地方是直接受到了 React 的启发。
Vue 从一开始的定位就是尽可能的降低前端开发的门槛,让更多的人能够更快地上手开发。
从加载速度、运行时性能来说,两者目前综合各种场景应该说是没有什么质的差别。硬要说的话,Vue 在 update 性能优化方面需要的心智负担可能少那么一点。

不同:
1.react基本上已经有一套遵循Flux的完整开发方案(基本上也就这一套大家默认的方式),而vue虽然有配合vuex使用,但是还有其他很多组织方式来解决,所以并不算是有固定模式,相对灵活很多,当然这个你可以看作是优势,也可以看作是不足
2.react社区还是要比vue大很多
3.react在view层侵入性还是要比vue大很多的
4.首次渲染性能,对于大量数据来说react还是比vue有优势
5.对于component的写法,react偏向于all in js,语法学习上需要下一些功夫,而vue配合vue-loader,其实在很大程度上让你不会觉得陌生--这不就是web component么。

Vue和React两个JavaScript框架都是当下比较受欢迎的,他们两者之间的区别有哪些,各自的优缺点是什么,本文将为你呈现。

正如我们之前提到的,WordPress 的核心团队正争论着为应该将哪款(前端框架)加入现在的架构之中。目前看来,暂时脱颖而出的是React与Vue.js,社区中的很多成员正权衡着这两款框架的利弊。

那到底哪款框架会胜出,哪款框架又会沦为昔日的prototype.js.呢?让我们一起看看吧。

我已经写出了两个几乎一样的web应用,一个是基于Vue,另一个则基于React,可以方便你在看这篇文章的时候查找相关代码。

React sample app
Vue sample app

简单介绍

除非你最近一直不关注前端的发展,不然你肯定听说过由Facebook创建的JavaScript UI框架——React。它支撑着包括Instagram在内的大多数Facebook网站。React与当时流行的jQuery,Backbone.js和Angular 1等框架不同,它的诞生改变了JavaScript的世界。其中最大的变化是React推广了Virtual DOM(我们稍后探究)并创造了新的语法——JSX,JSX允许开发者在JavaScript中书写HTML(译者注:即HTML in JavaScript)。WAT?

Vue致力解决的问题与React一致,但却提供了另外一套解决方案。Vue使用模板系统而不是JSX,使其对现有应用的升级更加容易。这是因为模板用的就是普通的HTML,通过Vue来整合现有的系统是比较容易的,不需要整体重构。同时Vue声称它更容易学习,我最近才接触Vue,能证明所言非虚。关于Vue还需要说的是,Vue主要是由一位开发者进行维护的,而不像React一样由如Facebook这类大公司维护。
相似之处

React与Vue存在很多相似之处,例如他们都是JavaScript的UI框架,专注于创造前端的富应用。不同于早期的JavaScript框架“功能齐全”,Reat与Vue只有框架的骨架,其他的功能如路由、状态管理等是框架分离的组件。
Virtual DOM

啊哈,人们经常说Virtual DOM是什么呢?

t019804d4b5dfd6da0b

Vue.js(2.0版本)与React的其中最大一个相似之处,就是他们都使用了一种叫'Virtual DOM'的东西。所谓的Virtual DOM基本上说就是它名字的意思:虚拟DOM,DOM树的虚拟表现。它的诞生是基于这么一个概念:改变真实的DOM状态远比改变一个JavaScript对象的花销要大得多。

Virtual DOM是一个映射真实DOM的JavaScript对象,如果需要改变任何元素的状态,那么是先在Virtual DOM上进行改变,而不是直接改变真实的DOM。当有变化产生时,一个新的Virtual DOM对象会被创建并计算新旧Virtual DOM之间的差别。之后这些差别会应用在真实的DOM上。

例子如下,我们可以看看下面这个列表在HTML中的代码是如何写的:

<ul class="list">
<li>item 1</li>
<li>item 2</li>
</ul>

而在JavaScript中,我们可以用对象简单地创造一个针对上面例子的映射:

{
type: 'ul',
props: {'class': 'list'},
children: [
{ type: 'li', props: {}, children: ['item 1'] },
{ type: 'li', props: {}, children: ['item 2'] }
]
}

真实的Virtual DOM会比上面的例子更复杂,但它本质上是一个嵌套着数组的原生对象。

当新一项被加进去这个JavaScript对象时,一个函数会计算新旧Virtual DOM之间的差异并反应在真实的DOM上。计算差异的算法是高性能框架的秘密所在,React和Vue在实现上有点不同。

Vue宣称可以更快地计算出Virtual DOM的差异,这是由于它在渲染过程中,会跟踪每一个组件的依赖关系,不需要重新渲染整个组件树。

而对于React而言,每当应用的状态被改变时,全部子组件都会重新渲染。当然,这可以通过shouldComponentUpdate这个生命周期方法来进行控制,但Vue将此视为默认的优化。

小结:如果你的应用中,交互复杂,需要处理大量的UI变化,那么使用Virtual DOM是一个好主意。如果你更新元素并不频繁,那么Virtual DOM并不一定适用,性能很可能还不如直接操控DOM。
组件化

React与Vue都鼓励组件化应用。这本质上说,是建议你将你的应用分拆成一个个功能明确的模块,每个模块之间可以通过合适的方式互相联系。关于组件化的例子可以在这篇文章的中间部分被找到:

你可以认为组件就是用户界面中的一小块。如果让我来设计Facebook的UI界面,那么聊天窗口会是一个组件,评论会是另一个组件,不断更新的好友列表也会作为一个组件。

在Vue中,如果你遵守一定的规则,你可以使用单文件组件.

//PastaItem.vue

<template>
<li class="pasta-dish list-unstyled">
<div class="row">
<div class="col-md-3">
<img :src="this.item.image" :alt="this.item.name" />
</div>
<div class="col-md-9 text-left">
<h3>{{this.item.name}}</h3>
<p>
{{this.item.desc}}
</p>
<button v-on:click="addToOrderNew" class="btn btn-primary">Add to order</button> <mark>{{this.orders}}</mark>
</div>
</div>
</li>
</template>

<script>

export default {
name: 'pasta-item',
props: ['item'],
data: function(){
return{
orders: 0
}
},
methods: {
addToOrderNew: function(y){
this.orders += 1;
this.$emit('order');
}
}
}

</script>

<style src="./Pasta.css"></style>

正如上面你看到的例子中,HTML, JavaScript和CSS都写在一个文件之中。你不再需要在.vue组件文件中引入CSS,虽然这也是可以的。

推荐你个博客,可以看下网页链接



你看我写的这个  你会发现豁然开朗网页链接




React和Vue有什么区别
Reactjs 和Vuejs的区别:Reactjs是一个适合数据经常变化以及构建大型项目的复杂组件,而Vue是一个更小更灵活适合用来开发单页面程序的简单化组件随着JavaScript越来越受欢迎,越来越多的框架随之出现,今天将为大家介绍两个流行框架间的比较React.js 和Vue.js,接下来在文章中将为大家详细介绍【推荐课程:...

react vue选哪一个
在React和Vue之间做选择,需要根据具体需求权衡。Vue以其易上手性吸引了不少开发者,特别是那些熟悉模板语言的后端或jQuery时代的程序员。Vue的设计理念强调简单使用,适合中小项目,组件化虽不如React纯粹但能满足大部分需求。React则更注重大型工程的开发,需要掌握函数组件、函数式编程等技术,且配合Type...

前端框架有哪些 知乎
前端框架有很多,其中比较知名的包括React、Vue、Angular、Bootstrap等。前端框架是用于构建网页和应用程序的工具集,它们提供了一套预定义的代码结构和组件,开发者可以使用这些工具和组件来快速构建出用户界面。以下是几个常见的前端框架的详细介绍:React React是一个用于构建用户界面的JavaScript库。它由Face...

Vue、Angular、React 全面对比,我们该选谁?
在Vue、React和Angular的选择中,Vue.js凭借其易用性和性能优势脱颖而出。尽管Angular 2受到Google支持且AngularJS有其历史地位,但Vue的轻量级设计和更直观的API使得开发者更容易上手。MVVM模式下的Vue提供了低耦合、可重用性和独立开发的便利,且在数据绑定和组件化方面表现出色。Vue.js作为MVVM框架,其...

React 和 Vue 该怎么选?为什么?
React 和 Vue 都是非常流行的前端框架,它们都有自己的优点和缺点。React 更适合大型应用程序,而 Vue 更适合小型应用程序。React 的学习曲线较陡峭,但一旦掌握了它,您就可以轻松地创建复杂的应用程序。Vue 的学习曲线较平缓,因此您可以更快地开始使用它。如果您想要更多的样式开发,推荐使用 Vue。发...

Vue、React 「实现原理」对比及前端框架发展史
现代应用通常采用同构方案,兼顾高性能和原生体验。随着jQuery、zepto的兴起,开发者开始依赖这些库简化DOM操作,MVVM框架如Vue、React的出现则进一步将数据绑定和DOM操作分离,逻辑层负责数据变化,物理层仍是DOM。前端框架如Vue的template语法更简洁,而React则通过JSX表达视图逻辑,各有优缺点。在数据驱动视图...

react和vue的区别
那么是先在Virtual DOM上进行改变,而不是直接改变真实的DOM。当有变化产生时,一个新的Virtual DOM对象会被创建并计算新旧Virtual DOM之间的差别。之后这些差别会应用在真实的DOM上。vue:渲染过程中是跟踪每一个组件的依赖,即更改了哪个组件渲染哪个。react:会重新渲染全部子组件。

React和Vue的区别
5、什么功能内置,什么交给社区去做:React做的事情很少,很多都交给社区去做,Vue很多东西都是内置的,写起来确实方便一些,比如Redux的combineReducer就对应Vuex的modules,比如reselect就对应Vuex的getter和Vue组件的computed,Vuex的mutation是直接改变的原始数据,而Redux的reducer是返回一个全新的state,所以...

学vue还是学react好
有条件的话,推荐是两个都学,上手感受一下才知道哪个更适合自己不是么?而且不同的公司要求不同,有的要会vue,有的要会react,如果都会的话,那找工作肯定也会更有优势一点的。两者之间的区别的话,vue会更实用一些,而且比较好上手,功能也多,在工程的制作也会更容易组织一些。而react的话则是...

vue和react的区别之我见
比如 redux的combineReducer就对应vuex的modules,比如reselect就对应vuex的getter和vue组件的computed,vuex的mutation是直接改变的原始数据,而redux的reducer是返回一个全新的state,所以redux结合immutable来优化性能,vue不需要。上面主要梳理了react和vue的4点不同:(其中第3点在vue3.0支持类式写法之后就...

嫩江县19184479927: 怎么理解VUE,VUE的数据驱动原理是什么,解释 -
喻贾金葡: Vue是一个基于MVVM模式数据驱动页面的框架,它将数据绑定在视图上.属于实现单页面应用的技术.首先,vuejs在实例化的过程中,会对实例化对象选项中的data 选项进行遍历,遍历其所有属性并使用 Object.defineProperty 把这些属性全部...

嫩江县19184479927: 认识Vue.js+Vue.js的优缺点+和与其他前端框架的区别 -
喻贾金葡: Vue.js与其他框架的区别? 1.与AngularJS的区别 相同点: 都支持指令:内置指令和自定义指令. 都支持过滤器:内置过滤器和自定义过滤器. 都支持双向数据绑定. 都不支持低端浏览器. 不同点: 1.AngularJS的学习成本高,比如增加了...

嫩江县19184479927: vue和react是属于前端还是后端 -
喻贾金葡: 属于前端框架,是目前比较流行的框架, Vue.js 是一套构建用户界面的渐进式框架. Vue 只关注视图层, 采用自底向上增量开发的设计. React主要用于构建UI.你可以在React里传递多种类型的参数,如声明代码,帮助你渲染出UI、也可以是静态的HTML DOM元素、也可以传递动态变量、甚至是可交互的应用组件.

嫩江县19184479927: angular和vue还有jquery的区别 -
喻贾金葡: React和Vue有许多相似之处,它们都有:1.使用VirtualDOM2.提供了响应式(Reactive)和组件化(Composable)的视图组件.3.将注意力集中保持在核心库,伴随于此,有配套的路由和负责处理全局状态管理的库.React和Vue的区别:1.复杂

嫩江县19184479927: Vue和React区别 -
喻贾金葡: Vue 通过 getter/setter 以及一些函数的劫持,能精确知道数据变化,不需要特别的优化就能达到很好的性能.React 默认是通过比较引用的方式进行的,如果不优化,可能导致大量不必要的VDOM的重新渲染.Vue 使用的是可变数据,而React更强调数据的不可变.Vue更加简单,而React构建大型应用的时候更加鲁棒.

嫩江县19184479927: VueJs与ReactJS和AngularJS的异同点 -
喻贾金葡: React && Vue React 和 Vue 有许多相似之处,它们都有: 使用 Virtual DOM 提供了响应式(Reactive)和组件化(Composable)的视图组件. 将注意力集中保持在核心库,伴随于此,有配套的路由和负责处理全局状态管理的库. 由于有着众多的相似处,我们会用更多的时间在这一块进行比较.这里我们不只保证技术内容的准确性,同时也兼顾了平衡的考量.我们需要指出 React 比 Vue 更好的地方,像是他们的生态系统和丰富的自定义渲染器. React && Vue的性能 渲染性能 在渲染用户界面的时候,DOM 的操作成本是最高的,不幸的是没有库可以让这些原始操作变得更快.

嫩江县19184479927: 什么是Vue.js框架 为什么选择它 -
喻贾金葡: Vue.js是一个交互性较强的前端框架,去Vue.js官方中文网,首页会展示一段小视频,里面说明了Vue.js的简单又基本的用法. 登录前端库或GitHub,Vue的热门度,正义极快的速度增长,成为目前最流行的框架,没有之一.当然,我只是说,就...

嫩江县19184479927: vue.js和angularjs的区别 -
喻贾金葡: 选择 Vue 而不选择 Angular,有下面几个原因,当然不是对每个人都适合: 在 API 与设计两方面上 Vue.js 都比 Angular 简单得多,因此你可以快速地掌握它的全部特性并投入开发. Vue.js 是一个更加灵活开放的解决方案.它允许你以希望的方...

嫩江县19184479927: Vue 和 React 的使用场景和深度有何不同 -
喻贾金葡: 首先,其实 Vue 也完全可以全量赋值的,唯一需要的小优化就是给 v-repeat 列表一个 track-by 属性,提示一下如何判断两个对象是否是同一份数据.如果是没有复杂交互的列表,可以直接 track-by="$index" 原地复用 DOM 元素.合理使用 ...

嫩江县19184479927: 和React 比起来 Vue.js 好用吗 -
喻贾金葡: vue的上手难度更低,而且是渐进式的框架,起初可以当模板来使用.随着学习的深入可以慢慢上vue全家桶.而且是国人出品,文档详细.讲真,同类框架中,vue的文档绝对是最棒的.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网