Software

Microsoft looks to React Native as a way to tackle the cross-platform development puzzle

Windows and Office teams shun Xamarin in favour of JavaScript/C++ solution


Ignite Microsoft has hinted that cross-platform development framework React Native is a key solution to the problem of writing applications that span both Windows and mobile.

Cross-platform development is critical for Microsoft since both first-party and third-party apps accessing Office 365 or Azure services need to run on iOS and Android as well as on Windows. Underlining the point, the company has announced Surface Duo, a dual-screen Android device expected towards the end of next year.

In 2016 the company acquired Xamarin, enabling development for iOS, Android and macOS using C# and .NET. Microsoft has also invested in .NET Core, which runs on Windows, macOS and Linux.

Initially aimed at server development, .NET Core is evolving to support desktop Windows applications. Microsoft has also said that .NET 5 will be available in late 2020, and will "target Windows, Linux, macOS, iOS, Android, tvOS, watchOS and WebAssembly and more".

Despite all this activity, Microsoft is not depending entirely on .NET for cross-platform development. There are a couple of reasons for this. One is that the Windows team has historically been wary of .NET and the overhead of the Common Language Runtime (CLR), preferring to develop in C++ for performance reasons. WinUI, which is the next-generation API for Windows desktop applications, is built in C++. Second, the company is keen to appeal to developers beyond the .NET community, especially the huge number who are familiar with JavaScript and web technology.

Tangled in .NET: Will 5.0 really unify Microsoft's development stack?

READ MORE

React Native ticks all these boxes. The React web framework was developed by Facebook for building a user interface in JavaScript. In 2015 Facebook released React Native, which lets you use React for mobile applications for iOS and Android. React Native for Windows, sponsored by Microsoft, enables the framework to target Windows 10 UWP (Universal Windows Platform) or WPF (Windows Presentation Foundation) for Windows 7 and higher. The UWP version uses native WinUI controls. Developers can code in JavaScript or TypeScript, and tooling is provided for the popular Visual Studio Code editor.

UWP with C++ is best for performance, according to this slide from Microsoft

React Native for Windows generates .NET code, but this will be replaced with a C++ implementation in an upcoming release, currently called vNext. Presenting the plans at Ignite, Microsoft program managers Kalita Saintonge and Steven Moyes said that the vNext version, which should be production-ready by the end of 2019, reduces memory requirements and improves performance. They also noted that React Native is much leaner than the Electron framework, another cross-platform solution, because it does not require an embedded browser engine.

There are several clues concerning the importance Microsoft attaches to React Native. One is that it is already being used by the Office team. If you right-click in the latest Word, for example, and add a comment, the pop-up box that appears is written in React Native. So too is the forthcoming Office Calendar application, now in preview. These applications use the vNext implementation, rather than .NET.

"You might be thinking, could I use React Native to target the new [Surface] devices? The answer to that question is, we hope so," said Moyes, showing a slide depicting Surface Duo. "React Native is building native applications, it stands to reason that React is a great platform for building apps that target multiple platforms."

Microsoft's official line is that Xamarin and React Native are equally good choices for targeting Windows and mobile, and that Xamarin is the sensible choice for those with existing C# code or skills, but it looks like React Native with C++ code generation is favoured by the Windows and Office teams for best performance.

What about Windows 7? This is an issue for business applications in companies that still use Windows 7, or for any Windows developer who wants the widest reach. You can do this in React Native using the WPF version, but Moyes was not keen. "I believe we have a WPF component as well but most of our active investment is happening in the UWP layer. WPF… is more of a community module," he told Ignite attendees. ®

Send us news
19 Comments

Microsoft hits go on Windows 11 24H2: Fresh features, bugs, and a whole lotta AI

Complete with Copilot Vision – but sessions won't be stored, insists Redmond

Germany is monitoring Microsoft to thwart 'anti-competitive practices'

Wants to peer into gaps in DMA to keep Redmond honest in cloud and AI

So how's Microsoft's Secure Future Initiative going?

34,000 engineers pledged to the cause, but no word on exec pay

Google files first ever complaint with European Commission against Microsoft

Mountain View versus Redmond: Fight over cloud software licensing policies gets formal

Office 2024 unveiled for Microsoft 365 refuseniks

For the IT professional who has to take work home

Recall the Recall recall? Microsoft thinks it can make that Windows feature palatable

AI screengrab service to be opt-in, features encryption, biometrics, enclaves, more

Saying goodbye to the tech dreams Microsoft abandoned with Windows 11 24H2

Is that a Mixed Reality headset, or just a complicated paperweight? Oh and farewell WordPad

Microsoft throws in the towel on HoloLens 2

Five years of mixed reality – now just mixed feelings

Microsoft issues 117 patches – some for flaws already under attack

Plus: SAP re-patches a failed patch for critical-rated flaw

Ransomware gang using stolen Microsoft Entra ID creds to bust into the cloud

Defenders beware: Data theft, extortion, and backdoors on Storm-0501's agenda

SAP offers different way to move SQL Server-based software to the cloud

Just don’t call it an alternative to RISE with SAP

Windows 11 Patch Tuesday preview is a glitchy disaster

Blue is the color of some screens after optional KB5043145 update