Introduction: This paper briefly describes the process of PC client business in the library, including the early stage of technology selection, scheme design, PC client cross-platform principle, as well as the application details of Electron framework. From application to principle, it explains PC client cross-platform technology, how to achieve cross-platform rendering, how to achieve native API call, and how to build applications for different target platforms. By reading this article, you can quickly start the development of PC client business based on Electron framework.

The full text is 2545 words, and the expected reading time is 7 minutes

preface

Cross-platform technology has been developed for many years on mobile client platforms (Android & iOS), from Hybrid apps to mini apps, React Native and Flutter have been widely used. Whether it is a front-end solution, a bridge solution or a self-rendering solution, three problems need to be solved:

  • How do I render UI?

  • How to implement native API calls?

  • How to do client build?

Different mobile client cross-platform schemes have their own solutions, but on PC client platform, most of the traditional application software is mainly developed on a single platform. Recently, Library business has started the project of PC client, which supports both Windows platform and MacOS platform. From the perspective of technology, it hopes to adapt to the rhythm of Internet products with lower cost and more efficient iteration through the cross-platform technology of PC client, and at the same time ensure the consistent experience of different platforms. This article through the PC client cross-platform framework analysis and cross-platform business applications.

First, technology selection

The PC client of library mainly involves the desktop OS of Windows and MacOS. The current application software development of these two platforms includes single platform development, intermediate platform development and cross-platform development. According to the structure and familiarity of the research and development personnel of library business, Flutter and Electron are the key cross-platform frameworks to look at for PC clients. Because the library has accumulated technology in document page rendering, which can be quickly reused to business scenes, the Electron cross-platform technology scheme is finally selected.

Ii. Introduction of Electron frame

Next, what exactly is the Electron frame? How to implement cross-platform? To get back to the general issues that need to be addressed across platforms, UI rendering, native apis, client builds. The Electron framework mainly solves the following problems:

  • Integration of rendering and services, i.e. integration of UI and underlying services;

  • Different platform system API call and packaging;

  • Application construction under different platforms;

The difficulty to understand the principle of Electron framework lies in how Chromium and Node.js can communicate with each other, because we know that they both have their own independent event cycles, and the fusion of rendering and service cannot be realized without solving this problem, so we need to understand the multi-process architecture of Electron first.

2.1 Electron multi-process architecture

The Electron multi-process architecture is a reference to Chromium’s multi-process architecture, which isolates the renderer process from the main process. It is designed this way because it is similar to the evolution of the OS from single-user to multi-task, in order to avoid a faulty page or plug-in bug causing the entire browser and all tabs to close. Each browser TAB uses a separate process to protect the entire application from bugs and glitches in the rendering process. In actual business, UI is carried out in the rendering process. When system services such as I/O, DB, Push and so on are needed, they are implemented in the main process through IPC. The Electron framework itself has provided IPC capabilities, including ipcMain and ipcRenderer. You can query the Electron official document for detailed description and application examples.

2.2 Integration of Chromium and Node.js

Communication between Chromium and Node.js systems is one of the key problems solved by Electron. According to the official introduction, we first tried to replace Chromium message loop with Libuv, and each platform has its own GUI message loop. The implementation process was relatively complex and was eventually abandoned because resource consumption and latency issues could not be effectively addressed. Currently, the Electron framework implements Chromium and Node.js fusion by polling Node’s event loop in a separate thread. Concrete implementation can view the framework source code, this article does not expand the description.

Node_bindings. Cc source source address: https://github.com/electron/electron/blob/master/shell/common/node_bindings.ccCopy the code

= = =

Iii. Electron business practice

3.1 Multi-process scheme

Library also adopts the multi-process scheme similar to Chromium, in which the main process is responsible for the invocation of native services and the provision of business services, as well as the management of Windows. Each Window can be understood as a rendering process. The rendering process includes the main Window (shown in the green 1 area) and the content Window (shown in the red 2 area). The content Window is reused because creating and releasing the Window in actual use takes significant load time, and more Windows will increase the memory footprint. Therefore, whether switching the navigation bar or label is loaded through the content Window, and the page state is recorded to achieve the state recovery of the page, as well as off-screen rendering.


3.2 Rapid iteration based on online business

Part of the PC client page is consistent with the online page, so there is no need to repeat the development of this part, try to reuse online business, the main work is to carry out PC client adaptation of the online page, page layout, view shielding, self-adaptation and so on. At present, injection is used to achieve this. In addition, online business is often changing, so the injected code is controlled by the cloud as far as possible. The specific method is to inject through Window, BrowserWindow and webContent in WebView. In this case, the page life cycle needs to be detected and injected after the page is loaded.


3.3 the Debug and Release

The Electron framework will compile and package the code, and it takes a certain amount of time to run the client program each time during development, which greatly affects efficiency. Therefore, it can be run through Node service in Debug mode and compiled and packaged in Release mode to achieve wySIWYG in development.

= = =

Iv. Summary and outlook

In addition to the application of the Electron framework on PC clients, the Library business has also introduced the Flutter framework on mobile clients and used the new framework to reconstruct document-related capabilities. With the release of Flutter 2.0, more PC client friendly support, and the library business document capability building based on Flutter, it is possible to build full platform version clients of Windows, MacOS, Android, and iOS using Flutter.

Recommended reading:

When technology refactoring meets DDD, how to achieve business and technology win-win?

Interface documents automatically change? Baidu programmer development efficiency MAX secret

Tech reveal! Baidu search medium low code exploration and practice

Baidu intelligent cloud combat – static file CDN acceleration

Simplify the complex – Baidu intelligent small program master data architecture practice summary

Baidu search in Taiwan mass data management cloud native and intelligent practice

Baidu search “mixed” join information, how to rely on AI to solve?

———- END ———-

Baidu said Geek

Baidu official technology public number online!

Technical dry goods, industry information, online salon, industry conference

Recruitment information · Internal push information · technical books · Baidu surrounding

Welcome to your attention