


Detaillierte Erläuterung der Verwendung von React-Komponenten höherer Ordnung
Die Definition von Komponenten höherer Ordnung erfolgt analog zur Definition von Funktionen höherer Ordnung. Funktionen höherer Ordnung empfangen Funktionen als Parameter und geben eine Funktion zurück. Ebenso erhalten Komponenten höherer Ordnung eine React-Komponente als Parameter und geben eine neue React-Komponente zurück. Komponenten höherer Ordnung sind im Wesentlichen eine Funktion, keine Komponente. Stellen Sie sicher, dass Sie das nicht falsch verstehen.
Warum führt React das Konzept der Komponenten höherer Ordnung ein? Wie mächtig ist es? Lassen Sie es uns zunächst anhand eines einfachen Beispiels erklären.
Angenommen, es gibt eine Komponente MyComponent
, die Daten von LocalStorage
abrufen und die Daten dann an die Schnittstelle rendern muss. Wir können Komponentencode wie folgt schreiben:
import React, { Component } from 'react' class MyComponent extends Component { componentWillMount() { let data = localStorage.getItem('data'); this.setState({data}); } render() { return <p>{this.state.data}</p> } }
Der Code ist sehr einfach, aber wenn andere Komponenten dieselben Daten von LocalStorage
abrufen und anzeigen müssen, müssen sie dies in jedem Komponentencode wiederholen , was offensichtlich sehr überflüssig ist. Schauen wir uns an, wie dieser Teil des Codes mithilfe von Komponenten höherer Ordnung neu geschrieben werden kann. componentWillMount
import React, { Component } from 'react' function withPersistentData(WrappedComponent) { return class extends Component { componentWillMount() { let data = localStorage.getItem('data'); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } } const MyComponentWithPersistentData = withPersistentData(MyComponent2)
ist eine Komponente höherer Ordnung. Sie gibt eine neue Komponente zurück. Die Logik zum Abrufen von Daten aus withPersistentData
wird einheitlich im componentWillMount
der neuen Komponente verarbeitet und anschließend werden die erhaltenen Daten verarbeitet as Attribute werden an die verpackte Komponente LocalStorage
übergeben, sodass WrappedComponent
direkt in WrappedComponent
verwendet werden kann, um die Daten zu erhalten, die angezeigt werden müssen, wie in this.props.data
gezeigt. Wenn auch andere Komponenten diese Logik benötigen, verwenden Sie einfach weiterhin die Komponente MyComponent2
höherer Ordnung, um diese Komponenten zu umschließen. withPersistentData
Komponenten höherer Ordnung darin besteht, die gemeinsame Logik von Komponenten zu kapseln und zu trennen, sodass die gemeinsame Logik zwischen Komponenten besser wiederverwendet werden kann . Diese Implementierung von Komponenten höherer Ordnung ist im Wesentlichen ein Dekorator-Entwurfsmuster.
Der Parameter einer Komponente höherer Ordnung ist nicht nur eine Komponente, er kann auch andere Parameter erhalten. Beispielsweise muss die Komponente die Daten mit dem Schlüssel gleich „name“ von LocalStorage abrufen, anstelle der fest codierten Daten mit dem Schlüssel „data“ im obigen Beispiel. Diese höherwertige Komponente MyComponent3
entspricht nicht unseren Anforderungen . Wir können es einen zusätzlichen Parameter empfangen lassen, um zu entscheiden, welche Daten von withPersistentData
abgerufen werden sollen: LocalStorage
import React, { Component } from 'react' function withPersistentData(WrappedComponent, key) { return class extends Component { componentWillMount() { let data = localStorage.getItem(key); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } class MyComponent3 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } const MyComponent2WithPersistentData = withPersistentData(MyComponent2, 'data'); const MyComponent3WithPersistentData = withPersistentData(MyComponent3, 'name');
kann unsere Anforderungen erfüllen, die Werte verschiedener Schlüssel zu erhalten. Parameter in Komponenten höherer Ordnung können natürlich auch Funktionen sein, was wir im nächsten Abschnitt näher erläutern. withPersistentData
HOC([param])([WrappedComponent])
, wie folgt: withPersistentData
import React, { Component } from 'react' const withPersistentData = (key) => (WrappedComponent) => { return class extends Component { componentWillMount() { let data = localStorage.getItem(key); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } class MyComponent3 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } const MyComponent2WithPersistentData = withPersistentData('data')(MyComponent2); const MyComponent3WithPersistentData = withPersistentData('name')(MyComponent3);
derzeit von unserer ursprünglichen Definition von Komponenten höherer Ordnung. Es ist zu einer Funktion höherer Ordnung geworden, aber der Rückgabewert withPersistentData
dieser Funktion höherer Ordnung ist eine Komponente höherer Ordnung. In dieser Form ist HOC([param])([WrappedComponent])
die eigentliche Komponente höherer Ordnung. Wir können sie uns als eine Variante einer Komponente höherer Ordnung vorstellen. Diese Form von Komponenten höherer Ordnung erscheint aufgrund ihrer einzigartigen Zweckmäßigkeit – klare Struktur (Trennung von gewöhnlichen Parametern und verpackten Komponenten) und einfache Kombination – in großer Zahl in Bibliotheken von Drittanbietern. Ein typisches Beispiel ist beispielsweise die Verbindung in React-Redux. Die Definition von connect lautet wie folgt: HOC([param])
connect([mapStateToProps], [mapDispatchToProps], [mergeProps], [options])(WrappedComponent)
aus dem globalen Speicher und konvertiert den Status gleichzeitig über den Funktionstypparameter , die aktuelle Komponente Die verwendeten Redux-Aktionsersteller werden in Form von Requisiten an die aktuelle Komponente übergeben. mapStateToProps
mapDispatchToProps
Zum Beispiel ist die Art und Weise, wie wir Komponente ComponentA mit Redux verbinden, ähnlich:
const ConnectedComponentA = connect(mapStateToProps, mapDispatchToProps)(ComponentA);
Wir können es aufteilen und betrachten:
// connect 是一个函数,返回值enhance也是一个函数 const enhance = connect(mapStateToProps, mapDispatchToProps); // enhance是一个高阶组件 const ConnectedComponentA = enhance(ComponentA);
当多个函数的输出和它的输入类型相同时,这些函数是很容易组合到一起使用的。例如,有f,g,h三个高阶组件,都只接受一个组件作为参数,于是我们可以很方便的嵌套使用它们:f( g( h(WrappedComponent) ) )
。这里可以有一个例外,即最内层的高阶组件h可以有多个参数,但其他高阶组件必须只能接收一个参数,只有这样才能保证内层的函数返回值和外层的函数参数数量一致(都只有1个)。
例如我们将connect和另一个打印日志的高阶组件withLog
联合使用:
const ConnectedComponentA = connect(mapStateToProps)(withLog(ComponentA));
这里我们定义一个工具函数:compose(...functions)
,调用compose(f, g, h)
等价于 (...args) => f(g(h(...args)))
。用compose
函数我们可以把高阶组件嵌套的写法打平:
const enhance = compose( connect(mapStateToProps), withLog ); const ConnectedComponentA = enhance(ComponentA);
像Redux等很多第三方库都提供了compose
的实现,compose
结合高阶组件使用,可以显著提高代码的可读性和逻辑的清晰度。
4.与父组件区别
有些同学可能会觉得高阶组件有些类似父组件的使用。例如,我们完全可以把高阶组件中的逻辑放到一个父组件中去执行,执行完成的结果再传递给子组件。从逻辑的执行流程上来看,高阶组件确实和父组件比较相像,但是高阶组件强调的是逻辑的抽象。高阶组件是一个函数,函数关注的是逻辑;父组件是一个组件,组件主要关注的是UI/DOM。如果逻辑是与DOM直接相关的,那么这部分逻辑适合放到父组件中实现;如果逻辑是与DOM不直接相关的,那么这部分逻辑适合使用高阶组件抽象,如数据校验、请求发送等。
5. 注意事项
1)不要在组件的render方法中使用高阶组件,尽量也不要在组件的其他生命周期方法中使用高阶组件。因为高阶组件每次都会返回一个新的组件,在render中使用会导致每次渲染出来的组件都不相等(===
),于是每次render,组件都会卸载(unmount),然后重新挂载(mount),既影响了效率,又丢失了组件及其子组件的状态。高阶组件最适合使用的地方是在组件定义的外部,这样就不会受到组件生命周期的影响了。
2)如果需要使用被包装组件的静态方法,那么必须手动拷贝这些静态方法。因为高阶组件返回的新组件,是不包含被包装组件的静态方法。hoist-non-react-statics可以帮助我们方便的拷贝组件所有的自定义静态方法。有兴趣的同学可以自行了解。
3)Refs不会被传递给被包装组件。尽管在定义高阶组件时,我们会把所有的属性都传递给被包装组件,但是ref
并不会传递给被包装组件。如果你在高阶组件的返回组件中定义了ref
,那么它指向的是这个返回的新组件,而不是内部被包装的组件。如果你希望获取被包装组件的引用,你可以把ref
的回调函数定义成一个普通属性(给它一个ref以外的名字)。下面的例子就用inputRef这个属性名代替了常规的ref命名:
function FocusInput({ inputRef, ...rest }) { return <input>; } //enhance 是一个高阶组件 const EnhanceInput = enhance(FocusInput); // 在一个组件的render方法中... return (<enhanceinput> { this.input = input } }>) // 让FocusInput自动获取焦点 this.input.focus();</enhanceinput>
下篇预告:
React 深入系列7:React 常用模式
我的新书《React进阶之路》已上市,请大家多多支持!
链接:京东 当当
React 深入系列,深入讲解了React中的重点概念、特性和模式等,旨在帮助大家加深对React的理解,以及在项目中更加灵活地使用React。
1. 基本概念
高阶组件是React 中一个很重要且比较复杂的概念,高阶组件在很多第三方库(如Redux)中都被经常使用。在项目中用好高阶组件,可以显著提高代码质量。
Die Definition von Komponenten höherer Ordnung erfolgt analog zur Definition von Funktionen höherer Ordnung. Funktionen höherer Ordnung empfangen Funktionen als Parameter und geben eine Funktion zurück. Ebenso erhalten Komponenten höherer Ordnung eine React-Komponente als Parameter und geben eine neue React-Komponente zurück. Komponenten höherer Ordnung sind im Wesentlichen eine Funktion, keine Komponente. Stellen Sie sicher, dass Sie das nicht falsch verstehen.
2. Anwendungsszenarien
Warum führt React das Konzept der Komponenten höherer Ordnung ein? Wie mächtig ist es? Lassen Sie es uns zunächst anhand eines einfachen Beispiels erklären.
Angenommen, es gibt eine Komponente MyComponent
, die Daten von LocalStorage
abrufen und die Daten dann an die Schnittstelle rendern muss. Wir können Komponentencode wie folgt schreiben:
import React, { Component } from 'react' class MyComponent extends Component { componentWillMount() { let data = localStorage.getItem('data'); this.setState({data}); } render() { return <p>{this.state.data}</p> } }
Der Code ist sehr einfach, aber wenn andere Komponenten dieselben Daten von LocalStorage
abrufen und anzeigen müssen, müssen sie dies in jedem Komponentencode wiederholen , was offensichtlich sehr überflüssig ist. Schauen wir uns an, wie dieser Teil des Codes mithilfe von Komponenten höherer Ordnung neu geschrieben werden kann. componentWillMount
import React, { Component } from 'react' function withPersistentData(WrappedComponent) { return class extends Component { componentWillMount() { let data = localStorage.getItem('data'); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } } const MyComponentWithPersistentData = withPersistentData(MyComponent2)
ist eine Komponente höherer Ordnung. Sie gibt eine neue Komponente zurück. Die Logik zum Abrufen von Daten aus withPersistentData
wird einheitlich im componentWillMount
der neuen Komponente verarbeitet und anschließend werden die erhaltenen Daten verarbeitet as Attribute werden an die verpackte Komponente LocalStorage
übergeben, sodass WrappedComponent
direkt in WrappedComponent
verwendet werden kann, um die Daten zu erhalten, die angezeigt werden müssen, wie in this.props.data
gezeigt. Wenn auch andere Komponenten diese Logik benötigen, verwenden Sie einfach weiterhin die Komponente MyComponent2
höherer Ordnung, um diese Komponenten zu umschließen. withPersistentData
Komponenten höherer Ordnung darin besteht, die gemeinsame Logik von Komponenten zu kapseln und zu trennen, sodass die gemeinsame Logik zwischen Komponenten besser wiederverwendet werden kann . Diese Implementierung von Komponenten höherer Ordnung ist im Wesentlichen ein Dekorator-Entwurfsmuster.
Der Parameter einer Komponente höherer Ordnung ist nicht nur eine Komponente, er kann auch andere Parameter erhalten. Beispielsweise muss die Komponente die Daten mit dem Schlüssel gleich „name“ von LocalStorage abrufen, anstelle der fest codierten Daten mit dem Schlüssel „data“ im obigen Beispiel. Diese höherwertige Komponente MyComponent3
entspricht nicht unseren Anforderungen . Wir können es einen zusätzlichen Parameter empfangen lassen, um zu entscheiden, welche Daten von withPersistentData
abgerufen werden sollen: LocalStorage
import React, { Component } from 'react' function withPersistentData(WrappedComponent, key) { return class extends Component { componentWillMount() { let data = localStorage.getItem(key); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } class MyComponent3 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } const MyComponent2WithPersistentData = withPersistentData(MyComponent2, 'data'); const MyComponent3WithPersistentData = withPersistentData(MyComponent3, 'name');
kann unsere Anforderungen erfüllen, die Werte verschiedener Schlüssel zu erhalten. Parameter in Komponenten höherer Ordnung können natürlich auch Funktionen sein, was wir im nächsten Abschnitt näher erläutern. withPersistentData
HOC([param])([WrappedComponent])
, wie folgt: withPersistentData
import React, { Component } from 'react' const withPersistentData = (key) => (WrappedComponent) => { return class extends Component { componentWillMount() { let data = localStorage.getItem(key); this.setState({data}); } render() { // 通过{...this.props} 把传递给当前组件的属性继续传递给被包装的组件WrappedComponent return <wrappedcomponent></wrappedcomponent> } } } class MyComponent2 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } class MyComponent3 extends Component { render() { return <p>{this.props.data}</p> } //省略其他逻辑... } const MyComponent2WithPersistentData = withPersistentData('data')(MyComponent2); const MyComponent3WithPersistentData = withPersistentData('name')(MyComponent3);
derzeit von unserer ursprünglichen Definition von Komponenten höherer Ordnung. Es ist zu einer Funktion höherer Ordnung geworden, aber der Rückgabewert dieser Funktion höherer Ordnung ist eine Komponente höherer Ordnung. withPersistentData
In dieser Form ist HOC([param])([WrappedComponent])
die eigentliche Komponente höherer Ordnung. Wir können sie uns als eine Variante einer Komponente höherer Ordnung vorstellen. Diese Form von Komponenten höherer Ordnung erscheint aufgrund ihrer einzigartigen Zweckmäßigkeit – klare Struktur (Trennung von gewöhnlichen Parametern und verpackten Komponenten) und einfache Kombination – in großer Zahl in Bibliotheken von Drittanbietern. Ein typisches Beispiel ist beispielsweise die Verbindung in React-Redux. Die Definition von connect lautet wie folgt: HOC([param])
connect([mapStateToProps], [mapDispatchToProps], [mergeProps], [options])(WrappedComponent)
aus dem globalen Speicher und konvertiert den Status gleichzeitig über den Funktionstypparameter , die aktuelle Komponente Die verwendeten Redux-Aktionsersteller werden in Form von Requisiten an die aktuelle Komponente übergeben. mapStateToProps
mapDispatchToProps
Zum Beispiel ist die Art und Weise, wie wir Komponente ComponentA mit Redux verbinden, ähnlich:
const ConnectedComponentA = connect(mapStateToProps, mapDispatchToProps)(ComponentA);
Wir können es aufteilen und betrachten:
// connect 是一个函数,返回值enhance也是一个函数 const enhance = connect(mapStateToProps, mapDispatchToProps); // enhance是一个高阶组件 const ConnectedComponentA = enhance(ComponentA);
Bei der Ausgabe mehrerer Funktionen Diese Funktionen lassen sich leicht kombinieren, wenn ihre Eingabetypen gleich sind. Beispielsweise gibt es drei höherwertige Komponenten f, g, h, die alle nur eine Komponente als Parameter akzeptieren, sodass wir sie leicht verschachteln können:
. Hier kann es eine Ausnahme geben, das heißt, die innerste Komponente h kann mehrere Parameter haben, andere Komponenten höherer Ordnung dürfen jedoch nur einen Parameter erhalten Funktionsparameter der äußeren Schicht gewährleistet sein (jeweils nur 1).f( g( h(WrappedComponent) ) )
Zum Beispiel verwenden wir die Verbindung mit einer anderen höherwertigen Komponente
const ConnectedComponentA = connect(mapStateToProps)(withLog(ComponentA));
这里我们定义一个工具函数:compose(...functions)
,调用compose(f, g, h)
等价于 (...args) => f(g(h(...args)))
。用compose
函数我们可以把高阶组件嵌套的写法打平:
const enhance = compose( connect(mapStateToProps), withLog ); const ConnectedComponentA = enhance(ComponentA);
像Redux等很多第三方库都提供了compose
的实现,compose
结合高阶组件使用,可以显著提高代码的可读性和逻辑的清晰度。
4.与父组件区别
有些同学可能会觉得高阶组件有些类似父组件的使用。例如,我们完全可以把高阶组件中的逻辑放到一个父组件中去执行,执行完成的结果再传递给子组件。从逻辑的执行流程上来看,高阶组件确实和父组件比较相像,但是高阶组件强调的是逻辑的抽象。高阶组件是一个函数,函数关注的是逻辑;父组件是一个组件,组件主要关注的是UI/DOM。如果逻辑是与DOM直接相关的,那么这部分逻辑适合放到父组件中实现;如果逻辑是与DOM不直接相关的,那么这部分逻辑适合使用高阶组件抽象,如数据校验、请求发送等。
5. 注意事项
1)不要在组件的render方法中使用高阶组件,尽量也不要在组件的其他生命周期方法中使用高阶组件。因为高阶组件每次都会返回一个新的组件,在render中使用会导致每次渲染出来的组件都不相等(===
),于是每次render,组件都会卸载(unmount),然后重新挂载(mount),既影响了效率,又丢失了组件及其子组件的状态。高阶组件最适合使用的地方是在组件定义的外部,这样就不会受到组件生命周期的影响了。
2)如果需要使用被包装组件的静态方法,那么必须手动拷贝这些静态方法。因为高阶组件返回的新组件,是不包含被包装组件的静态方法。hoist-non-react-statics可以帮助我们方便的拷贝组件所有的自定义静态方法。有兴趣的同学可以自行了解。
3)Refs不会被传递给被包装组件。尽管在定义高阶组件时,我们会把所有的属性都传递给被包装组件,但是ref
并不会传递给被包装组件。如果你在高阶组件的返回组件中定义了ref
,那么它指向的是这个返回的新组件,而不是内部被包装的组件。如果你希望获取被包装组件的引用,你可以把ref
的回调函数定义成一个普通属性(给它一个ref以外的名字)。下面的例子就用inputRef这个属性名代替了常规的ref命名:
function FocusInput({ inputRef, ...rest }) { return <input>; } //enhance 是一个高阶组件 const EnhanceInput = enhance(FocusInput); // 在一个组件的render方法中... return (<enhanceinput> { this.input = input } }>) // 让FocusInput自动获取焦点 this.input.focus();</enhanceinput>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
react实现选中li高亮步骤详解
EasyCanvas绘图库在Pixeler项目开发中使用实战总结
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Verwendung von React-Komponenten höherer Ordnung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



CrystalDiskMark ist ein kleines HDD-Benchmark-Tool für Festplatten, das schnell sequentielle und zufällige Lese-/Schreibgeschwindigkeiten misst. Lassen Sie sich als Nächstes vom Redakteur CrystalDiskMark und die Verwendung von CrystalDiskMark vorstellen ). Zufällige I/O-Leistung. Es ist eine kostenlose Windows-Anwendung und bietet eine benutzerfreundliche Oberfläche und verschiedene Testmodi zur Bewertung verschiedener Aspekte der Festplattenleistung. Sie wird häufig in Hardware-Reviews verwendet

foobar2000 ist eine Software, die Ihnen jederzeit Musik aller Art mit verlustfreier Klangqualität bietet Spielen Sie das erweiterte Audio auf dem Computer ab, um ein bequemeres und effizienteres Musikwiedergabeerlebnis zu ermöglichen. Das Interface-Design ist einfach, klar und benutzerfreundlich. Es nimmt einen minimalistischen Designstil an, ohne übermäßige Dekoration Es unterstützt außerdem eine Vielzahl von Skins und Themes, personalisiert Einstellungen nach Ihren eigenen Vorlieben und erstellt einen exklusiven Musikplayer, der die Wiedergabe mehrerer Audioformate unterstützt. Außerdem unterstützt es die Audio-Gain-Funktion zum Anpassen der Lautstärke Passen Sie die Lautstärke entsprechend Ihrem Hörzustand an, um Hörschäden durch zu hohe Lautstärke zu vermeiden. Als nächstes lass mich dir helfen

NetEase Mailbox ist eine von chinesischen Internetnutzern weit verbreitete E-Mail-Adresse und hat mit seinen stabilen und effizienten Diensten schon immer das Vertrauen der Benutzer gewonnen. NetEase Mailbox Master ist eine E-Mail-Software, die speziell für Mobiltelefonbenutzer entwickelt wurde. Sie vereinfacht das Senden und Empfangen von E-Mails erheblich und macht unsere E-Mail-Verarbeitung komfortabler. Wie Sie NetEase Mailbox Master verwenden und welche spezifischen Funktionen es bietet, wird Ihnen der Herausgeber dieser Website im Folgenden ausführlich vorstellen und hofft, Ihnen weiterzuhelfen! Zunächst können Sie die NetEase Mailbox Master-App im Mobile App Store suchen und herunterladen. Suchen Sie im App Store oder im Baidu Mobile Assistant nach „NetEase Mailbox Master“ und befolgen Sie dann die Anweisungen zur Installation. Nachdem der Download und die Installation abgeschlossen sind, öffnen wir das NetEase-E-Mail-Konto und melden uns an. Die Anmeldeschnittstelle ist wie unten dargestellt

Cloud-Speicher sind heutzutage aus unserem täglichen Leben und Arbeiten nicht mehr wegzudenken. Als einer der führenden Cloud-Speicherdienste in China hat Baidu Netdisk mit seinen leistungsstarken Speicherfunktionen, der effizienten Übertragungsgeschwindigkeit und dem komfortablen Bedienerlebnis die Gunst einer großen Anzahl von Benutzern gewonnen. Und egal, ob Sie wichtige Dateien sichern, Informationen teilen, Videos online ansehen oder Musik hören möchten, Baidu Cloud Disk kann Ihre Anforderungen erfüllen. Viele Benutzer verstehen jedoch möglicherweise nicht die spezifische Verwendung der Baidu Netdisk-App. Dieses Tutorial führt Sie daher im Detail in die Verwendung der Baidu Netdisk-App ein. Wenn Sie immer noch verwirrt sind, folgen Sie bitte diesem Artikel, um mehr im Detail zu erfahren. So verwenden Sie Baidu Cloud Network Disk: 1. Installation Wählen Sie beim Herunterladen und Installieren der Baidu Cloud-Software zunächst die benutzerdefinierte Installationsoption aus.

MetaMask (auf Chinesisch auch Little Fox Wallet genannt) ist eine kostenlose und beliebte Verschlüsselungs-Wallet-Software. Derzeit unterstützt BTCC die Bindung an die MetaMask-Wallet. Nach der Bindung können Sie sich mit der MetaMask-Wallet schnell anmelden, Werte speichern, Münzen kaufen usw. und bei der erstmaligen Bindung einen Testbonus von 20 USDT erhalten. Im BTCCMetaMask-Wallet-Tutorial stellen wir detailliert vor, wie man MetaMask registriert und verwendet und wie man das Little Fox-Wallet in BTCC bindet und verwendet. Was ist die MetaMask-Wallet? Mit über 30 Millionen Nutzern ist MetaMask Little Fox Wallet heute eines der beliebtesten Kryptowährungs-Wallets. Die Nutzung ist kostenlos und kann als Erweiterung im Netzwerk installiert werden

Apple hat am Dienstag das iOS 17.4-Update veröffentlicht, das eine Reihe neuer Funktionen und Korrekturen für iPhones bringt. Das Update enthält neue Emojis und EU-Nutzer können diese auch aus anderen App-Stores herunterladen. Darüber hinaus stärkt das Update auch die Kontrolle der iPhone-Sicherheit und führt weitere Einstellungsoptionen für den „Schutz gestohlener Geräte“ ein, um Benutzern mehr Auswahl und Schutz zu bieten. „iOS17.3 führt zum ersten Mal die Funktion „Schutz vor gestohlenen Geräten“ ein, die den vertraulichen Informationen der Benutzer zusätzliche Sicherheit verleiht. Wenn der Benutzer nicht zu Hause oder an anderen vertrauten Orten ist, erfordert diese Funktion, dass der Benutzer zum ersten Mal biometrische Informationen eingibt Zeit und nach einer Stunde müssen Sie Informationen erneut eingeben, um auf bestimmte Daten zuzugreifen und diese zu ändern, z. B. um Ihr Apple-ID-Passwort zu ändern oder den Schutz vor gestohlenen Geräten zu deaktivieren.

Die Xiaomi-Autosoftware bietet Funktionen zur Fernsteuerung des Fahrzeugs, mit denen Benutzer das Fahrzeug über Mobiltelefone oder Computer fernsteuern können, z. B. das Öffnen und Schließen der Türen und Fenster des Fahrzeugs, das Starten des Motors, die Steuerung der Klimaanlage und des Audios des Fahrzeugs usw. Folgendes ist Lassen Sie uns gemeinsam mehr über die Verwendung und den Inhalt dieser Software erfahren. Umfassende Liste der Funktionen und Nutzungsmethoden der Xiaomi Auto-App. 1. Die Xiaomi Auto-App wurde am 25. März im Apple AppStore gestartet und kann jetzt im App Store auf Android-Telefonen heruntergeladen werden: Erfahren Sie mehr über die wichtigsten Highlights und technischen Parameter von Xiaomi Auto und vereinbaren Sie einen Termin für eine Probefahrt. Konfigurieren und bestellen Sie Ihr Xiaomi-Auto und unterstützen Sie die Online-Abwicklung von Aufgaben zur Autoabholung. 3. Community: Informationen zur Marke Xiaomi Auto verstehen, Autoerfahrungen austauschen und das wundervolle Autoleben teilen: Das Mobiltelefon ist die Fernbedienung, Fernbedienung, Echtzeitsicherheit, einfach

Chirp Down kann auch als JJDown bezeichnet werden. Dies ist ein speziell für Bilibili entwickeltes Video-Download-Tool. Viele Freunde verstehen jedoch nicht, was Chirp Down ist. So verwenden Sie Chirp Down. 1. Der Ursprung von Chirpdown Chirpdown liegt im Jahr 2014. Es handelt sich um eine sehr alte Video-Download-Software. Die Benutzeroberfläche übernimmt den Win10-Kachelstil, der einfach, schön und leicht zu bedienen ist. Chirna ist das Aushängeschild von Chirpdown und die Künstlerin ist あさひクロイ. Jijidown war stets bestrebt, Benutzern das beste Download-Erlebnis zu bieten, die Software ständig zu aktualisieren und zu optimieren, verschiedene Probleme und Fehler zu beheben und neue Funktionen und Features hinzuzufügen. Die Funktion von Chirp Down Chirp Down ist
