StackShareStackShare
Follow on
StackShare

Discover and share technology stacks from companies around the world.

Follow on

© 2025 StackShare. All rights reserved.

Product

  • Stacks
  • Tools
  • Feed

Company

  • About
  • Contact

Legal

  • Privacy Policy
  • Terms of Service
  1. Stackups
  2. Application & Data
  3. Frameworks
  4. Cross Platform Mobile Development
  5. Flutter vs React Native vs Xamarin

Flutter vs React Native vs Xamarin

OverviewDecisionsComparisonAlternatives

Overview

Xamarin
Xamarin
Stacks1.3K
Followers1.5K
Votes785
React Native
React Native
Stacks34.4K
Followers29.5K
Votes1.2K
GitHub Stars124.4K
Forks24.9K
Flutter
Flutter
Stacks17.7K
Followers16.8K
Votes1.2K
GitHub Stars173.7K
Forks29.4K

Flutter vs React Native vs Xamarin: What are the differences?

Comparison between Flutter, React Native, and Xamarin

Flutter, React Native, and Xamarin are popular frameworks used for developing cross-platform mobile applications. It is essential to understand their key differences to choose the most suitable option for your project.

  1. Performance and User Interface: Flutter has a native-like performance due to its use of Dart programming language and its own rendering engine. It allows the creation of highly customized and appealing user interfaces. React Native utilizes a bridge to communicate with the native components, which may cause lags in performance. Xamarin uses C# and compiles the code into native apps, providing better performance compared to React Native but not as efficient as Flutter.

  2. Development Time: Flutter offers a Hot Reload feature that enables developers to instantly view changes during development without restarting the application. This significantly reduces development time and enhances developer productivity. React Native also offers Hot Reload, but it is not as fast as Flutter. Xamarin lacks a similar feature, which may hamper development speed.

  3. Community and Ecosystem: React Native has a larger community and a vast ecosystem of ready-to-use components and libraries. It benefits from being backed by Facebook, leading to continuous support and updates. Flutter's community is growing rapidly, and several packages and libraries are available, but it may not have the same level of maturity as React Native. Xamarin has a smaller community and a more limited ecosystem in comparison.

  4. Platform Support: React Native provides excellent support for both iOS and Android, allowing developers to access platform-specific features through various native modules. Flutter also supports iOS and Android and has its own set of widgets, offering a consistent look and feel across platforms. Xamarin provides the most extensive platform support, including iOS, Android, Windows, macOS, and even wearable devices.

  5. Learning Curve: Flutter uses the Dart programming language, which may require developers to learn a new language. However, the syntax is easy to understand for those with prior experience in object-oriented programming. React Native uses JavaScript, a widely adopted language, making it easier for developers to get started. Xamarin, on the other hand, uses C#, which may require developers to learn a new language.

  6. Integration with Native Code: React Native provides an extensive bridge that allows seamless integration with existing native code. It is beneficial when leveraging existing native libraries or using platform-specific features. Flutter also supports integration with native code but may require more effort compared to React Native. Xamarin simplifies native code integration by offering direct access to native APIs through its shared codebase.

In Summary, Flutter offers superior performance and highly customizable user interfaces, while React Native has a larger community and better ecosystem support. Xamarin provides extensive platform support and easy integration with native code. The choice between these frameworks depends on the specific project requirements, development speed, and familiarity with the programming languages.

Share your Stack

Help developers discover the tools you use. Get visibility for your team's tech choices and contribute to the community's knowledge.

View Docs
CLI (Node.js)
or
Manual

Advice on Xamarin, React Native, Flutter

Nick
Nick

CTO at Pickio

Jun 2, 2020

Decided

We built the first version of our app with RN and it turned out a mess in a while. A lot of bugs along with poor performance out of the box for a fairly large app. Many things, that native platform has, cannot be done with existing solutions for RN. For instance, large titles on iOS are not fully implemented in any of existing navigations libraries. Also there's painfully slow JSON bridge and many other small, yet annoying things. On the other hand Flutter became a really powerful and easy-to-use tool. A bit of a learning curve, of course, because of Dart, but it worth learning. Flutter offers TONS of built-in features, no JSON-bridge, AOT compilation for iOS.

491k views491k
Comments
John
John

Feb 11, 2021

Decided

Our stack roughly divides into three major components, the front-end, back-end and the data storage.

For the front-end, we have decided to go with React Native via Expo. This allows us to target both Android and iOS with a single codebase. Expo provides "managed workflows" and an SDK that will simplify development and deployment.

For the back-end, we have decided to use Python. Python is the language of choice for machine learning (ML). It has extensive support for traditional ML algorithms (e.g. random forests) via Scikit-Learn and the SciPy ecosystem. On top of this, our industry partner has provided us their current solution written in Python. We decided to expose the back-end as a REST API using FastAPI. This allows us to nicely separate concerns from the rest of the codebase. FastAPIs use of static type hints, validation with Pydantic, and automated documentation allows us to build better APIs faster.

For data storage we decided to use a MongoDB Atlas, a NoSQL database. We decided to use a NoSQL database because we need to store large amounts of data (e.g data from the wearable IMUs). Moreover, due to the ever changing nature of a startup we require flexibility. NoSQL databases are schema-free which enables us to modify our schema as we see fit.

We plan on using GitHub Actions (GA) to orchestrate our CI/CD. Given GAs broad support of languages and workflows, it's hard to go wrong with this decision. We will also be using GitHub for version control and project management, so having everything in one place is convenient.

The major components of our CI/CD for the backend will consist of black for autoformatting, flake8 for linting, pytest for unit-testing, and mypy for static type checking and codecov for coverage reporting. We plan to use separate Docker containers to package the back-end and front-end components and use Docker Compose to launch the app. This allows us to better separate concerns, manage dependencies, and ensure our app is deployable anywhere.

109k views109k
Comments
Andrea
Andrea

May 26, 2020

Needs adviceonVue.jsVue.jsVue NativeVue NativeReactReact

I'm a huge fan of Vue.js and I'm pretty comfortable with it. I need to build a mobile app for my company and I was now wondering whether I could make use of VueJS with Vue Native instead of switching to React. I know Vue Native builds on top of RN. My question is whether I'd have as much freedom with Vue Native over RN and whether you feel like Vue Native is "production ready" or not. Not sure of which shortcomings I may find using Vue Native... Thanks a lot!!!

336k views336k
Comments

Detailed Comparison

Xamarin
Xamarin
React Native
React Native
Flutter
Flutter

Xamarin’s Mono-based products enable .NET developers to use their existing code, libraries and tools (including Visual Studio*), as well as skills in .NET and the C# programming language, to create mobile applications for the industry’s most widely-used mobile devices, including Android-based smartphones and tablets, iPhone, iPad and iPod Touch.

React Native enables you to build world-class application experiences on native platforms using a consistent developer experience based on JavaScript and React. The focus of React Native is on developer efficiency across all the platforms you care about - learn once, write anywhere. Facebook uses React Native in multiple production apps and will continue investing in React Native.

Flutter is a mobile app SDK to help developers and designers build modern mobile apps for iOS and Android.

Cross-platform development- Thinking about supporting iOS, Android, Mac and Windows? Xamarin allows you to write it all in C#.;Reuse existing code- Use your favorite .NET libraries in Xamarin apps. Easily use third-party native libraries and frameworks.; Discover as you type- Explore APIs as you type with code autocompletion.;Visual Studio or Xamarin Studio- Create, build, debug, and deploy apps in Visual Studio. Or use Xamarin Studio, a fully-featured IDE that is built for mobile app development.;Native UI, Native Performance- Xamarin delivers high performance compiled code with full access to all the native APIs so you can create native apps with device-specific experiences.; Point and Click UI Design- Xamarin provides a world class Android UI designer. Use Apple Xcode UI designer to create interfaces and Storyboards that automatically sync with your Xamarin.iOS project.
Native iOS Components;Asynchronous Execution;Touch Handling;Flexbox and Styling; Polyfills
Fast development - Flutter's "hot reload" helps you quickly and easily experiment, build UIs, add features, and fix bug faster. Experience sub-second reload times, without losing state, on emulators, simulators, and hardware for iOS and Android.;Expressive UIs - Delight your users with Flutter's built-in beautiful Material Design and Cupertino (iOS-flavor) widgets, rich motion APIs, smooth natural scrolling, and platform awareness.;Access native features and SDKs - Make your app come to life with platform APIs, 3rd party SDKs, and native code. Flutter lets you reuse your existing Java, Swift, and ObjC code, and access native features and SDKs on iOS and Android.
Statistics
GitHub Stars
-
GitHub Stars
124.4K
GitHub Stars
173.7K
GitHub Forks
-
GitHub Forks
24.9K
GitHub Forks
29.4K
Stacks
1.3K
Stacks
34.4K
Stacks
17.7K
Followers
1.5K
Followers
29.5K
Followers
16.8K
Votes
785
Votes
1.2K
Votes
1.2K
Pros & Cons
Pros
  • 121
    Power of c# on mobile devices
  • 81
    Native performance
  • 79
    Native apps with native ui controls
  • 73
    No javascript - truely compiled code
  • 67
    Sharing more than 90% of code over all platforms
Cons
  • 9
    Build times
  • 5
    Visual Studio
  • 4
    Price
  • 3
    Scalability
  • 3
    Complexity
Pros
  • 214
    Learn once write everywhere
  • 174
    Cross platform
  • 169
    Javascript
  • 122
    Native ios components
  • 69
    Built by facebook
Cons
  • 23
    Javascript
  • 19
    Built by facebook
  • 12
    Cant use CSS
  • 4
    30 FPS Limit
  • 2
    Some compenents not truly native
Pros
  • 149
    Hot Reload
  • 126
    Cross platform
  • 107
    Performance
  • 90
    Backed by Google
  • 74
    Compiled into Native Code
Cons
  • 29
    Need to learn Dart
  • 11
    Lack of community support
  • 10
    No 3D Graphics Engine Support
  • 8
    Graphics programming
  • 6
    Lack of friendly documentation
Integrations
No integrations availableNo integrations available
Android SDK
Android SDK
Firebase
Firebase
Dart
Dart

What are some alternatives to Xamarin, React Native, Flutter?

Ionic

Ionic

Free and open source, Ionic offers a library of mobile and desktop-optimized HTML, CSS and JS components for building highly interactive apps. Use with Angular, React, Vue, or plain JavaScript.

NativeScript

NativeScript

NativeScript enables developers to build native apps for iOS, Android and Windows Universal while sharing the application code across the platforms. When building the application UI, developers use our libraries, which abstract the differences between the native platforms.

Apache Cordova

Apache Cordova

Apache Cordova is a set of device APIs that allow a mobile app developer to access native device function such as the camera or accelerometer from JavaScript. Combined with a UI framework such as jQuery Mobile or Dojo Mobile or Sencha Touch, this allows a smartphone app to be developed with just HTML, CSS, and JavaScript.

Framework7

Framework7

It is a free and open source mobile HTML framework to develop hybrid mobile apps or web apps with iOS native look and feel. All you need to make it work is a simple HTML layout and attached framework's CSS and JS files.

Qt

Qt

Qt, a leading cross-platform application and UI framework. With Qt, you can develop applications once and deploy to leading desktop, embedded & mobile targets.

PhoneGap

PhoneGap

PhoneGap is a web platform that exposes native mobile device apis and data to JavaScript. PhoneGap is a distribution of Apache Cordova. PhoneGap allows you to use standard web technologies such as HTML5, CSS3, and JavaScript for cross-platform development, avoiding each mobile platforms' native development language. Applications execute within wrappers targeted to each platform, and rely on standards-compliant API bindings to access each device's sensors, data, and network status.

Expo

Expo

It is a framework and a platform for universal React applications. It is a set of tools and services built around React Native and native platforms that help you develop, build, deploy, and quickly iterate on iOS, Android, and web apps.

Vue Native

Vue Native

Vue Native is a mobile framework to build truly native mobile app using Vue.js. Its is designed to connect React Native and Vue.js. Vue Native is a wrapper around React Native APIs, which allows you to use Vue.js and compose rich mobile User Interface.

Shoutem UI

Shoutem UI

Shoutem UI is a set of styleable components that enables you to build beautiful React Native applications for iOS and Android. All of our components are built to be both composable and customizable.

Sencha Touch

Sencha Touch

Sencha Touch 2, a high-performance HTML5 mobile application framework, is the cornerstone of the Sencha HTML5 platform. Built for enabling world-class user experiences, Sencha Touch 2 is the only framework that enables developers to build fast and impressive apps that work on iOS, Android, BlackBerry, Kindle Fire, and more.

Related Comparisons

Bootstrap
Materialize

Bootstrap vs Materialize

Laravel
Django

Django vs Laravel vs Node.js

Bootstrap
Foundation

Bootstrap vs Foundation vs Material UI

Node.js
Spring Boot

Node.js vs Spring-Boot

Liquibase
Flyway

Flyway vs Liquibase