Heim  >  Artikel  >  Web-Frontend  >  Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

coldplay.xixi
coldplay.xixinach vorne
2020-09-28 16:18:262178Durchsuche

Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

Verwandte Lernempfehlungen: WeChat Mini-Programmentwicklungs-Tutorial

Nach vielen Demonstrationen und Monaten der Forschung und Entwicklung haben wir einen Teil der untersten Ebene von Vue neu geschrieben und Das neu strukturierte Das uni-app-Framework hat die Leistung des WeChat-Clients verdoppelt und unterstützt mehr Vue-SyntaxVue底层、重构uni-app框架,实现了微信端性能翻倍及更多Vue语法支持。

背景

uni-app在初期借鉴了mpvue,实现了微信小程序端的快速兼容,感谢美团点评团队对于开源社区的贡献!

随着使用uni-app的开发者愈来愈多,业务复杂度不断增加,不少开发者抱怨uni-app支持的vue语法少,某些场景性能有问题(特别是页面存在复杂组件的情况),这些问题其实是由mpvue的实现机制导致的,我们以复杂组件的性能问题为例简要说明。

mpvue/wepy 等框架诞生之初,微信小程序尚不支持自定义组件,无法进行组件化开发;mpvue/wepy 为解决这个问题,创造性的将用户编写的Vue组件,编译为WXML中的模板(template),这样变相实现了组件化开发能力,提高代码复用性,这在当时的技术条件下是很棒的技术方案。但如此方案,也导致Vue组件中的数据会被编译为Page中的数据,对组件进行数据更新也会基于路径映射调用Page.setData。特别是组件较多、数据量交大的页面中,每个组件的局部更新会引发页面级别的全局更新,产生极大的性能开销。

微信后来推出的自定义组件,其实支持组件级别的局部更新,经验证,我们发现组件级别的数据更新,相比页面全局更新,有大幅性能提升。

另外,mpvue在Vue层进行的vnode对比及数据diff计算不彻底,也会消耗部分性能。

基于这些原因,我们开始了微信端的框架重写工作。

新版特性

性能翻倍

新版 uni-app 调整重写了部分Vue.js底层实现,主要包括:

  • 基于小程序自定义组件实现 Vue.js 的组件化开发
  • Vue层取消vnode对比
  • 更彻底的diff计算,setData().
  • Hintergrund

uni-app lernte von mpvue in der frühen Phase der Implementierung WeChat Dank der schnellen Kompatibilität des Miniprogramms, vielen Dank an das Meituan-Dianping-Team für seinen Beitrag zur Open-Source-Community!

Da immer mehr Entwickler uni-app verwenden, nimmt die Geschäftskomplexität weiter zu. Viele Entwickler beschweren sich darüber, dass uni-app weniger Vue-Syntax unterstützt Szenarien (insbesondere wenn komplexe Komponenten auf der Seite vorhanden sind) werden tatsächlich durch den Implementierungsmechanismus von mpvue verursacht. Wir werden die Leistungsprobleme komplexer Komponenten kurz erläutern.
  • Als Frameworks wie mpvue/wepy geboren wurden, unterstützten WeChat-Miniprogramme noch keine benutzerdefinierten Komponenten und konnten nicht in Komponenten entwickelt werden. Um dieses Problem zu lösen, kompilierte mpvue/wepy kreativ vom Benutzer geschriebene Vue-Komponenten in Vorlagen in WXML (template ), dadurch werden versteckte Komponentenentwicklungsfunktionen erreicht und die Wiederverwendbarkeit des Codes verbessert. Unter den damaligen technischen Bedingungen war dies eine großartige technische Lösung. Diese Lösung führt jedoch auch dazu, dass die Daten in der Vue-Komponente in die Daten in der Seite kompiliert werden und Datenaktualisierungen der Komponente auch Page.setData basierend auf der Pfadzuordnung aufrufen. Insbesondere bei Seiten mit vielen Komponenten und großen Datenmengen lösen lokale Aktualisierungen jeder Komponente globale Aktualisierungen auf Seitenebene aus, was zu einem enormen Leistungsaufwand führt.
  • Die später von WeChat eingeführten benutzerdefinierten Komponenten unterstützen tatsächlich Teilaktualisierungen auf Komponentenebene. Nach der Überprüfung haben wir festgestellt, dass Datenaktualisierungen auf Komponentenebene im Vergleich zu globalen Aktualisierungen auf der Seite eine erhebliche Leistungsverbesserung aufweisen.
  • Darüber hinaus sind der vnode-Vergleich von mpvue und die Datenberechnung diff in der Vue-Ebene nicht gründlich, wodurch auch ein Teil davon verbraucht wird Leistung.
Aus diesen Gründen haben wir mit der Neufassung des Frameworks für WeChat begonnen.

Neue Versionsfunktionen

Verdoppelung der Leistung

Die neue Version uni-app hat einen Teil der zugrunde liegenden Implementierung von Vue.js angepasst und neu geschrieben, hauptsächlich einschließlich: Implementierung von Vue.jsbasierend auf benutzerdefinierten Miniprogramm-Komponenten > Komponentenbasierte Entwicklung Vue-Ebene bricht vnode im Vergleich zu gründlicherer diff-Berechnung, setData()Weniger Kommunikationsdatenmenge Nachdem wir das neue Framework neu geschrieben haben, haben wir das folgende Testmodell erstellt: Erstellen Sie eine Listenschnittstelle, jedes Listenelement ist eine benutzerdefinierte Komponente Pull-up-Laden Löst jedes Mal eine Datenaktualisierung aus. Statische Daten lokal lesen, Netzwerkunterschiede abschirmenDer Zeitpunkt für die Datenaktualisierung wird gestartet, das Rendern der Seite ist abgeschlossen und der Zeitunterschied wird als Vergleichsindikator verwendet (zeitaufwändig, in Millisekunden)Dann Verwenden Sie jeweils das neue und das alte Framework, ermitteln Sie unter „Mehrere Tests auf demselben Mobiltelefon durchführen (vivo nex)“ den Durchschnitt und erhalten Sie die folgenden Ergebnisse: Anzahl der Komponentenaltes Framework (mpvue)neu Rahmen200204ms 129ms400280ms
🎜139ms🎜🎜🎜🎜800 🎜🎜341ms🎜🎜180ms🎜🎜🎜🎜1000 🎜🎜653ms🎜🎜196ms🎜🎜🎜 🎜

Den Testdaten zufolge hat sich die Leistung des neuen Frameworks auf komplexen Seiten verdoppelt! Insbesondere bei Seiten mit mehr Daten und komplexeren Komponenten wird die Leistungsverbesserung größer sein!

Tipps: Wir haben auch einen Leistungstest für mehrere aktuelle Mainstream-Cross-End-Frameworks (wie Taro, Wepy, Chameleon usw.) durchgeführt Zukunft, der Testcode. Die Testergebnisse sind öffentlich und können von jedem beurteilt werden, also bleiben Sie dran.

Mehr Vue-Syntaxunterstützung

Wir haben auch den uni-app-Compiler verbessert, um mehr Vue-Syntax zu unterstützen, wie unten beschrieben: uni-app编译器,支持了更多 Vue 语法,详细如下:

  • 支持过滤器 filter
  • 支持比较复杂的 JavaScript 渲染表达式
  • 支持在 template 内使用 methods 中的函数
  • 支持 v-html (同 rich-text 的解析)
  • 组件支持原生事件绑定,如:@tap.native

体验方式

目前新框架在微信端已完成开发,其他小程序和App的编译器仍为旧版。我们放出群测版,邀请开发者在微信端抢鲜体验。

开发者按照如下方式创建vue-cli并创建uni-app项目,编译发行到微信小程序:

# npm script# 全局安装vue-cli$ npm install -g @vue/cli# 创建uni-app项目,会提示选择项目模板,初次接触建议选择 hello uni-app 模板$ vue create -p dcloudio/uni-preset-vue my-project# 进入项目目录$ cd my-project# dev 模式,编译预览$ npm run dev:mp-weixin# build 模式,发行打包$ npm run build:mp-weixin复制代码

新老版本切换

为了不影响老项目,uni-app群测版目前同时内置新、老两个框架,且默认使用老框架,开发者可通过配置 manifest.json -> mp-weixin -> usingComponents节点启用新编译框架,如下:

// manifest.json
{
	// ...
	/* 小程序特有相关 */
	"mp-weixin": {
		"usingComponents":true //启用新框架编译,默认为false
	}
}复制代码

如果你使用了新增的vue语法,请注意只有H5和微信支持这些新语法,编译到其他平台时,要用条件编译处理。

Tips:

  • 为保证自定义组件兼容性,运行到微信开发者工具时,建议将微信基础库设置为最新版本。
  • 体验新框架时,有任何问题或者建议,欢迎到github提交 issue

现状与未来

春节过后,uni-app1.6版本发布,新增字节跳动小程序平台支持;至此,实现一套代码、7端发布!7端分别包括:App(iOS/Android)、小程序(微信/支付宝/百度/字节跳动)、H5平台,见下图:

Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

大量开发者热情涌入 uni-app 社区,目前已有几十个uni-app交流群,下图为一个500人的QQ交流群,创建2天即满群,开发者的热情可见一斑。

Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

Der Trick von uni-app, die Leistung von WeChat zu verdoppeln

目前,每天新创建的uni-app项目(包括测试项目)达数千个,案例过万,部分案例见uniapp.dcloud.io/case。与Taro等框架清一色微信小程序案例相比,uni-app跨端案例要丰富很多。

在小程序跨端框架中,uni-app也许是使用人数最多、跨端案例最丰富的前端框架。

近期,为活跃Vue多端开发生态,由uni-appmpvue团队联合举办的插件开发大赛正式开始了!欢迎各位开发者踊跃参与,制造轮子、造福社区的同时,顺手再拿个奖品(iphone Xs Max、4K显示器等奖品多多),一举多得^_^,点击了解详情。

接下来,uni-app团队将继续全力奔跑,在如下方面快速完善:

  • uni-app新框架兼容到其它平台
  • uni-ui 跨端UI库精致化
  • App端引入更多原生渲染,提升系能体验
  • 周边生态进一步完善,比如行业模板、跨端统计等

“为开发者而生”,不是口号,而是定位。

uni-app

  • Unterstützung von Filtern filter code>
  • Unterstützt komplexere JavaScript-Rendering-Ausdrücke
  • Unterstützt die Verwendung von Methoden innerhalb von <code>template-Funktionen in code>
  • Unterstützt v-html (gleiches Parsen wie rich-text)
  • Komponente unterstützt native Ereignisbindung, z : @tap.native

Erfahrungsmethode

Derzeit Die Entwicklung des Neuen Das Framework wurde auf WeChat fertiggestellt und die Compiler anderer Miniprogramme und Apps sind noch alte Versionen. Wir haben eine Gruppen-Betaversion veröffentlicht und Entwickler eingeladen, sie frühzeitig auf WeChat zu testen.

Entwickler erstellen vue-cli und erstellen ein Uni-App-Projekt wie folgt, kompilieren und veröffentlichen es im WeChat-Applet: rrreeeWechseln zwischen alten und neuen Versionen

In Um alte Projekte nicht zu beeinträchtigen, sind in der Gruppen-Betaversion von uni-app derzeit sowohl neue als auch alte Frameworks integriert, und das alte Framework wird standardmäßig verwendet. Entwickler können es über manifest konfigurieren .json -> ; mp-weixin -> Der Knoten usingComponents aktiviert das neue Kompilierungsframework wie folgt:
rrreee🎜Wenn Sie das neue vue verwenden Bitte beachten Sie, dass nur H5 und WeChat diese Syntax unterstützen. Diese neuen Syntaxen müssen beim Kompilieren auf anderen Plattformen mithilfe der bedingten Kompilierung verarbeitet werden. 🎜🎜Tipps: 🎜
  • Um die Kompatibilität benutzerdefinierter Komponenten sicherzustellen, wird beim Ausführen der WeChat-Entwicklertools empfohlen, die WeChat-Basisbibliothek auf die neueste Version einzustellen.
  • Wenn Sie beim Kennenlernen des neuen Frameworks Fragen oder Vorschläge haben, senden Sie bitte ein Problem an github

Aktueller Status und in der Zukunft

🎜Nach dem Frühlingsfest wird uni-app Version 1.6 veröffentlicht, die an dieser Stelle Unterstützung für die ByteDance Mini-Programmplattform bietet; und 7-End-Release wird erreicht! Zu den 7 Terminals gehören: App (iOS/Android), Miniprogramm (WeChat/Alipay/Baidu/Bytedance), H5-Plattform, siehe Bild unten: 🎜🎜Der Trick von uni-app, die Leistung von WeChat zu verdoppeln🎜🎜Eine große Anzahl von Entwicklern hat sich mit Begeisterung der Uni-App-Community angeschlossen, und das gibt es derzeit auch Dutzende von Uni-App-Kommunikationsgruppen. Das Bild unten zeigt eine QQ-Kommunikationsgruppe mit 500 Personen. Die Gruppe war innerhalb von 2 Tagen nach der Erstellung offensichtlich. 🎜🎜Der Trick von uni-app, die Leistung von WeChat zu verdoppeln🎜
Der Trick von uni-app, die Leistung von WeChat zu verdoppeln
🎜Derzeit werden neu erstellte Uni-App-Projekte (einschließlich Tests) erstellt Täglich erstellt (es gibt Tausende von Projekten) und über 10.000 Fälle. Weitere Informationen finden Sie unter uniapp.dcloud.io/case. Verglichen mit den WeChat-Applet-Fällen von Frameworks wie Taro sind die terminalübergreifenden Fälle von uni-app viel umfangreicher. 🎜🎜Unter den Cross-End-Frameworks für kleine Programme ist <code>uni-app möglicherweise das Front-End-Framework mit den meisten Benutzern und den umfangreichsten Cross-End-Fällen. 🎜🎜Um das Multi-Terminal-Entwicklungsökosystem von Vue zu aktivieren, wurde kürzlich der Plug-in-Entwicklungswettbewerb gemeinsam von uni-app und mpvue Teams hat offiziell begonnen! Entwickler sind herzlich eingeladen, aktiv mitzumachen und der Community zu helfen, aber auch Preise zu gewinnen (iPhone). 🎜🎜Als nächstes wird das <code>uni-app-Team weiterhin hart daran arbeiten, die folgenden Aspekte schnell zu verbessern: 🎜
  • Das neue Framework von uni-app ist mit anderen Plattformen kompatibel
  • Die terminalübergreifende Uni-UI-UI-Bibliothek wurde verfeinert
  • Die App-Seite führt mehr natives Rendering ein, um die Systemleistung zu verbessern
  • Die umgebende Ökologie wird weiter verbessert, z Branchenvorlagen, terminalübergreifende Statistiken usw.
  • li>
🎜„Geboren für Entwickler“ ist kein Slogan, sondern eine Positionierung. Das 🎜🎜uni-app-Team wird weiterhin Entwicklungsprobleme lösen und die Entwicklungseffizienz für Entwickler verbessern! 🎜🎜🎜Weitere weitere hervorragende Artikel finden Sie in der Rubrik 🎜uni-app🎜~🎜🎜🎜

Das obige ist der detaillierte Inhalt vonDer Trick von uni-app, die Leistung von WeChat zu verdoppeln. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:juejin.im. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen