Didi Technology – Didi open source lightweight cross-end development framework: Hummer
After two years of in-depth work, Hummer, the ultra-lightweight dynamic cross-end development framework jointly created by Didi Puhui and Didi R-Lab, has finally been opened to the public.
It consists of a very lean Hummer Core and a highly extensible Tenon Reactive Framework. At present, the scheme has been implemented on a large scale and operated stably in many business lines within didi Convergence, such as cashier desk, proxy driver end, proxy driver end, proxy driver end, errand rider end, errand merchant end, freight driver end, consignor end, two-wheeler and take-out end.
1. Business background
With the rapid expansion of multi-category and multi-scene business in the past two years, higher requirements have been put forward for the throughput capacity of the R&D team. How to support the rapid development of the business more efficiently under the premise of keeping the overall size of the team unchanged has become the primary consideration of the team, and cross-end development has become our primary choice. After investigating a number of cross-end solutions in the industry, we found that package volume control, overall stability, and start-up costs did not meet our needs. In this context, pratt & Whitney’s pan-front end team and R-Lab’s pan-front End team cooperated deeply and launched the Hummer Cross-end technology project at the end of 2018, aiming to produce a dynamic cross-end development framework with high productivity at a low cost and effectively integrate front-end and terminal development resources within the team. Truly improve the overall development efficiency of the team.
2. Technical advantages
The Hummer, as it is called, is small and light, with powerful, powerful wings and a brightly coloured appearance.
- Ultra-lightweight: the compiled product is less than 1M, which can be integrated into the App at a very low cost of package volume to create the ultimate lightweight advantage;
- Easy to get started: Hummer API + Tenon Reactive Framework gives consideration to both client and front-end development experience, creating a very low learning threshold;
- High availability: It has been fully verified in several internal businesses of Didi, with the overall Crash rate lower than 0.01%;
- High performance: Maximize the performance benefits of native rendering and platform capabilities based on native components and modules;
- Cross-platform: a set of code can be compiled and run on iOS and Android platforms, with Tenon can be quickly compatible with Vue based Web applications;
- Dynamic: Using JavaScript (JS) to explain execution, dynamic pages can be quickly deployed and published in the cloud with Hummer Nest platform;
A simple demo
To give you a sense of Hummer, let’s take a look at the code for the HelloWorld page developed using the Hummer API and Tenon.
As you can see, Hummer supports both the Native Hummer API model and the front-end Tenon (Vue compatible) model. In the near future, we will support more frameworks such as React and Angular.
Technical architecture and cross-end architecture
Based on the JS engine, Hummer implements a Fabric engine pass-through architecture similar to React Native, enabling Native objects and JS objects to interact with each other and achieve synchronous view rendering on the premise of keeping the least feature dependence on the JS engine. Make it take full advantage of the performance advantages of native rendering (currently support JavaScriptCore, V8, Hermers, QuickJS and other well-known JS engines in the industry). At the same time, through the component self-rendering ability, almost perfect control view rendering every detail, and then with the Yoga layout engine after tuning, erase the layout differences between the two ends of the view, so that the two ends of the view to maintain a high degree of consistency (better performance from the development of the layout engine).
As shown in the figure below, we have abandoned the technical implementation of DSL+VDOM commonly used by other cross-end frameworks in the industry in exchange for a near-native development experience and performance. But at the same time, we also provide a responsive development capability of the Tenon Framework, fully compatible with Vue 3.0 development Framework, close to W3C standards, comply with the rules of Web development, can easily transplant Web components, Embrace Web ecology (in development at Tenon for React).
In addition to this, we offer a complete suite of tools and a one-stop release management platform, Hummer Nest. Easy continuous integration and delivery of Hummer applications, online tracking of releases, release coverage, and activation rates. The platform also has the ability to report and alarm online crash information, which can easily control application quality and improve application stability.
The case shows
At present, the Hummer has on polymerization cashier SDK, generation of drivers & side, running errands riders and passengers, freight drivers side & the owner, the two rounds of car operation, international delivery client groups such as on a large scale in multiple lines of business within the landing and stable operation, here are some drops of online business Hummer page screenshots, effect and the original almost the same.
4. The conclusion
Hummer is a very young cross-end development framework, which is still in the period of rapid development. We really need your valuable opinions and suggestions. We welcome your active use and feedback, and we also welcome your active participation in the construction of Hummer to make Hummer better and more perfect. Looking forward to your PRs and Issues. We hope that Hummer will become the cross-end framework of choice for client development, and that it will actually help you save money and improve your development efficiency.
5. About us
Official website: hummer.didi.cn Official Github address: github.com/didi/Hummer Official email: [email protected] Hummer QQ communication group (851327307) for more information, welcome to pay attention to [Puhui product technology team] public number