Type | JavaScript Library | JavaScript Library |
Ideal for | Web and Native | Primarily focused on web development, but it is written to support other platforms moving forward |
Developer | Facebook Community (Created by Jordan Walke) | Evan You |
First Published | 2013 March | February 2014 |
Written | JavaScript | JavaScript |
Cross-platform development | React’s React Native is a mature and widely used native application platform | Vue’s Weex is still evolving and aims to provide a smooth development experience |
Learning curve | Steep learning curve, requires deep knowledge | Easy learning curve, HTML based template makes it familiar |
Popularity | React ranks second in the list of the most popular Javascript projects on GitHub | Vue.js ranks first and is the most fashionable project in 2017, during the year Over 40,000 stars added on GitHub |
Reusability | CSS only | Maximum reusability |
Performance | Also fast | Also fast |
Contributors on GitHub | 1201 | 189 |
##Model
Virtual DOM (Document Object Model) |
Virtual DOM HTML-based template |
|
Features
Can be used as a foundation for single page or mobile application development |
A web application framework capable of powering advanced single page applications |
|
Simple
React is more complex than Vue |
Vue is simpler than React |
|
Notable features
| One-way data binding using props Stateful Components Virtual DOM Lifecycle Methods JSX (JavaScript XML) Architectures other than HTML HTML-based templates | Reactive Components (divide the entire application into small, self-contained, often reusable components) Transformation Routing * Integration
|
Bootstrap Application
CRA (Create React Application) |
Vue-cli |
|
The difference between react and vuejs
1. Data binding
Related data in Vue The binding part
vue is two-way binding. There are two core functions of Vue.js, one is the responsive data binding system, and the other is the component system. The so-called two-way binding means that the data in the Vue instance is consistent with the content of the DOM element it renders. No matter who is changed, the other party will be updated to the same data accordingly. This is accomplished by setting property accessors.
In vue, data binding is related to interpolation expressions, instruction systems, *Class and Style, event handlers and form spaces, ajax requests and calculated properties
react does not have two-way binding of data
react is a one-way data flow
React achieves real-time updates and changes of data by two-way binding of state (Model layer) and View layer data , specifically, write JS code directly in the View layer and use the data in the Model layer to render. Once the data changes are triggered by form operations, trigger events, ajax requests, etc., dual synchronization will be performed
2. Re-rendering and optimization
When you compare React and Vue, speed cannot be an important comparison factor in deciding which one is better. In terms of performance, let's consider the re-render functionality. When a component's state changes, React's mechanism triggers a re-rendering of the entire component tree. You may want to use additional properties to avoid unnecessary re-rendering of child components.
While Vue's re-rendering functionality is available out of the box, Vue provides optimized re-rendering where the system tracks dependencies during the rendering process and works accordingly.
Re-rendering Vue is the most notable feature that makes it a widely accepted framework among developers all over the world.
3. JSX and HTML
React uses JSX - a declarative JavaScript XML that allows developers to write components using the power of JavaScript , while Vue.js uses HTML templates to create views.
HTML-based templates are more familiar and beneficial in improving existing applications to get the benefits of Vue's reactive features. This provides an easy learning curve for both beginners and experienced professionals, since most of them have worked with HTML in one way or another.
4. Routing and state management solutions
In component-based frameworks like React and Vue, when you start to extend the application When programming, you need to pay more attention to state management and data flow. This is because there are many components that interact with each other and share data.
In this case, React offers an innovative solution called Flux/Redux architecture, which stands for unidirectional data flow and is an alternative to the famous MVC architecture. Now, if we consider the Vue.js framework, there is a higher-level architecture called Vuex, which is integrated into Vue and provides an unparalleled experience.
5. Construction tools
Both React and Vue have a very good development environment. With little or no configuration, you can create applications that enable you to use the latest practices and templates. In React, there is Create React App (CRA), and in Vue, it is vue-cli.
Both bootstrap tools tend to provide you with a comfortable and flexible development environment and provide you with an excellent starting point to start coding.
Related recommendations: "vue.js Tutorial"