Lassen Sie mich Ihnen ein tieferes Verständnis davon vermitteln.$nextTick!
Es ist fast 2023, wissen Sie das nicht? $nextTick? Vue2 ist seit fast 10 Jahren auf dem Markt und Vue3 ist schon seit mehr als zwei Jahren auf dem Markt, das stimmt! Es ist peinlich, das zu sagen.NextTick jetzt (um ehrlich zu sein, lass es uns zuerst auf Baidu suchen, klick, klick, klick ... Ich bin schnell zum offiziellen Website-Dokument von Vue.js gesprungen und habe plötzlich eins gefunden Satz im Dokument? :
nextTick: Einen verzögerten Rückruf ausführen, nachdem die nächste DOM-Aktualisierungsschleife endet. Verwenden Sie diese Methode unmittelbar nach der Änderung der Daten, um das aktualisierte DOM zu erhalten. Es verfügt über zwei Parameter: Der erste Parameter ist
callback function
, der einen Promise-Aufruf bereitstellt, wenn er nicht übergeben wird; der zweite Parameter istexecution ambient context
, der standardmäßig auf automatische Bindung setzt, wenn er nicht übergeben wird . wird der Instanz zugewiesen, die es aufruft. [Verwandte Empfehlungen: vuejs Video-Tutorial, Web-Frontend-Entwicklung]回调函数
,不传时提供promise调用;第二个参数是执行环境上下文
,不传默认是自动绑定到调用它的实例上。【相关推荐:vuejs视频教程、web前端开发】
我们先看看nextTick究竟是个啥?
console.log(this.$nextTick); // 控制台打印 if(fn){ return nextTick(fn, this); }
我们可以看出nextTick就是一个方法,方法有两个参数:fn和this,fn就是需要传的回调函数,this就是所说的执行环境上下文。那么问题来了,在Vue中是如何实现在下一次DOM更新结束之后才会执行延迟回调的? 我们先看看下面的例子:
<div ref="test1">created:{{message}}</div> // vue实例 data: { message: "Hello World!", }, created(){ this.message = '你好,世界!'; console.log(this.$refs.test1.innerText);// 报错 // TypeError: Cannot read properties of undefined (reading 'innerText') this.$nextTick(()=>{ console.log('test1 nextTick:',this.$refs.test1.innerText);// 你好,世界! }); },
从上面例子中,在created生命周期中操作了DOM,但是我们都知道created生命周期只是初始化了数据,这期间是还没有渲染DOM的,如果我们直接操作DOM是找不到DOM元素的,那么问题来了:为什么放在nextTick中就可以获取到了DOM元素呢? 这不是很明显吗,等到DOM渲染完才调用不就获取到了吗,从而知道了nextTick作用就是用来等下次DOM渲染完才去调用nextTick内的DOM操作代码
console.log('同步代码1');
setTimeout(function () {
console.log("setTimeout");
}, 0);
new Promise((resolve) => {
console.log('同步代码2')
resolve()
}).then(() => {
console.log('promise.then')
})
console.log('同步代码3');
Wir können sehen, dass nextTick eine Methode ist: fn und dies ist die Callback-Funktion, die übergeben werden muss. this
ist der sogenannte Ausführungsumgebungskontext. Die Frage ist also: Wie implementiert man einen verzögerten Rückruf in Vue, bis das nächste DOM-Update abgeschlossen ist? Schauen wir uns zunächst das folgende Beispiel an:
// 同步代码1 // 同步代码2 // 同步代码3 // promise.then // setTimeoutAus dem obigen Beispiel wird das DOM im erstellten Lebenszyklus manipuliert, aber wir alle wissen, dass der erstellte Lebenszyklus nur die Daten initialisiert und das DOM nicht gerendert wurde Wenn wir in diesem Zeitraum keine DOM-Elemente finden, wenn wir DOM betreiben, stellt sich die Frage: Warum kann ich DOM-Elemente erhalten, indem ich sie in nextTick platziere? Ist das nicht offensichtlich? Sie können es erhalten, indem Sie warten, bis das DOM gerendert ist, und es dann aufrufen. Dann wissen Sie, dass die Funktion von
nextTick darin besteht, zu warten, bis das DOM das nächste Mal gerendert wird, bevor der DOM-Vorgang aufgerufen wird Code in nextTick
. Es stellt sich also wieder die Frage: Was genau macht nextTick? Lassen Sie uns das nextTick-Prinzip der Vue2- und Vue3-Versionen auf Quellcodeebene analysieren.
Vue2-Version von nextTick
- Da Vue Entwicklern die nextTick-Methode zur Verfügung stellt, werden in dieser Methode drei Hauptaufgaben erledigt:
- Hinzufügen der Rückruffunktion ,
, Beurteilen des aktuellen Ob die nextTick wird an die Callback-Funktion übergeben
- Die Rückruffunktion wird dem Rückrufarray hinzugefügt, da im aktuellen Bereich möglicherweise mehrere nextTick-Funktionen vorhanden sind.
Bestimmen Sie, ob der aktuelle nextTick als „pending=true“ markiert wurde, d. Die Ausführung von timerFunc bestimmt, ob die aktuelle Umgebung Promise, MutationObserver, SetImmediate und SetTimeout unterstützt, unterteilt in vier Situationen:
-
支持MutationObserver,HTML5的api,中文意思是:修改的监听,MutationObserver
用来监听DOM的变动
,比如节点的增减、属性的变动、文本内容的修改等都会触发MutationObserver事件。注意地,与事件不同,事件是同步触发,DOM的变动会立即触发事件,而MutationObserver事件是异步触发,DOM不会立即触发,需要等当前所有DOM操作完毕才会触发。
MutationObserver有7个属性:
childList
(true,监听子节点的变动)、attributes
(true,监听属性的变动)、characterData
(true,监听节点内容或节点文本的变动)、subtree
(是否应用于该节点的所有后代节点)、attributeOldValue
(观察attributes变动时,是否需要记录变动前的属性值)、characterDataOldValue
(观察characterData变动时,是否需要记录变动前的值)、attributeFilter
(数组,表示需要观察的特定属性(比如[‘class’,‘src’])。
为什么需要创建一个文本节点?因为在这里操作DOM保证浏览器页面是最新DOM渲染的,虽然看来好像是没什么作用,但这是保证拿到的DOM是最新的。
支持setImmediate、setTimeout,setImmediate即时计时器立即执行工作,它是在事件轮询之后执行,为了防止轮询阻塞,每次只会调用一个。setTimeout按照一定时间后执行回调函数。
好了好了,到了现在,我们都知道nextTick做了什么吧,但是我们有没有想过这样的一个问题:既然都是异步回调执行等待DOM更新后才去调用操作DOM的代码,那么这个机制又是什么原理?这就是JS的执行机制有关了,涉及宏任务与微任务的知识,我们先来看看这样的一道题:
console.log('同步代码1'); setTimeout(function () { console.log("setTimeout"); }, 0); new Promise((resolve) => { console.log('同步代码2') resolve() }).then(() => { console.log('promise.then') }) console.log('同步代码3');
我们可能会问上面的输出是个啥,首先js是单线程,所以在js程序运行中只有一个执行栈,实现不了多线程,所以就需要任务均衡分配,通俗的讲,按任务急优先处理原则,js中分为同步任务和异步任务,异步任务又分为宏任务和微任务,同步任务先入栈,程序会先把执行栈中的所有同步任务执行完,再去判断是否有异步任务,而异步任务中微任务的优先级高于宏任务。如果当前执行栈为空,而微任务队列不为空,就先执行微任务,等把所有微任务执行完,最后才会考虑宏任务。而上面代码中Promise是属于微任务
,而setTimeout是宏任务
,所以上面的输出为:
// 同步代码1 // 同步代码2 // 同步代码3 // promise.then // setTimeout
使用Vue2的nextTick
-
传入回调函数参数使用:
this.$nextTick(()=>{ // ...操作DOM的代码 })
-
不传入回调函数参数使用:
// 方式一 this.$nextTick().then(()=>{ // ...操作DOM的代码 }) // 方式二 await this.$nextTick(); // 后写操作DOM的代码
Vue3版本的nextTick
Vue3版本就没有Vue2版本的那么多环境支持,nextTick封装成了一个Promise异步回调函数执行。
// Vue3.2.45 // core-main\core-main\packages\runtime-core\src export function nextTick<T = void>( this: T, fn?: (this: T) => void ): Promise<void> { const p = currentFlushPromise || resolvedPromise return fn ? p.then(this ? fn.bind(this) : fn) : p }
使用Vue3的nextTick
-
传入回调函数使用
import { nextTick } from 'vue' // 引入 setup () { nextTick(()=>{ // ...操作DOM的代码 })
-
不传入回调函数的使用
import { nextTick } from 'vue' // 引入 setup () { // 方式一 nextTick().then(()=>{ // ...操作DOM的代码 }) // 方式二 await nextTick(); // 后写操作DOM的代码 }
总结
- nextTick可以通俗的当作一个Promise,所以nextTick属于微任务。
- nextTick在页面更新数据后,DOM更新,可以通俗理解为,nextTick就是用来支持操作DOM的代码及时更新渲染页面。也就是在数据变化后要执行的某个操作,而这个操作需要使用随数据改变而改变的DOM结构的时候,这个操作都应该放进Vue.nextTick()的回调函数中。
- 在Vue生命周期的created()钩子函数进行的DOM操作一定要放在Vue.nextTick()的回调函数中。
Das obige ist der detaillierte Inhalt vonLassen Sie mich Ihnen ein tieferes Verständnis davon vermitteln.$nextTick!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Vue.js eignet sich für schnelle Entwicklung und kleine Projekte, während React eher für große und komplexe Projekte geeignet ist. 1.Vue.js ist einfach und leicht zu lernen, geeignet für schnelle Entwicklung und kleine Projekte. 2.React ist leistungsstark und für große und komplexe Projekte geeignet. 3.. 4. Reacts komponentiertes und virtuelles DOM funktioniert gut, wenn es sich um komplexe Benutzeroberflächen- und datenintensive Anwendungen handelt.

Vue.js und reagieren jeweils ihre eigenen Vor- und Nachteile. Bei der Auswahl müssen Sie Teamfähigkeiten, Projektgröße und Leistungsanforderungen umfassend berücksichtigen. 1) Vue.js eignet sich für schnelle Entwicklung und kleine Projekte mit einer niedrigen Lernkurve, aber tiefe verschachtelte Objekte können Leistungsprobleme verursachen. 2) React ist für große und komplexe Anwendungen mit einem reichhaltigen Ökosystem geeignet, aber häufige Aktualisierungen können zu Leistungs Engpässen führen.

Vue.js eignet sich für kleine bis mittelgroße Projekte, während React für große Projekte und komplexe Anwendungsszenarien geeignet ist. 1) Vue.js ist einfach zu bedienen und ist für schnelle Prototypen und kleine Anwendungen geeignet. 2) React hat mehr Vorteile beim Umgang mit komplexem Zustandsmanagement und Leistungsoptimierung und ist für große Projekte geeignet.

Vue.js und React haben jeweils eigene Vorteile: Vue.js ist für kleine Anwendungen und schnelle Entwicklung geeignet, während React für große Anwendungen und komplexes Staatsmanagement geeignet ist. 1.Vue.js realisiert automatisches Update über ein reaktionsschnelles System, das für kleine Anwendungen geeignet ist. 2.React verwendet virtuelle DOM- und Diff -Algorithmen, die für große und komplexe Anwendungen geeignet sind. Bei der Auswahl eines Frameworks müssen Sie Projektanforderungen und Teamtechnologie -Stack in Betracht ziehen.

Vue.js und React jeweils haben ihre eigenen Vorteile, und die Auswahl sollte auf Projektanforderungen und Teamtechnologie -Stack beruhen. 1. Vue.js ist gemeinschaftsfreundlich und bietet reichhaltige Lernressourcen an, und das Ökosystem umfasst offizielle Tools wie Vuerouter, die vom offiziellen Team und der Community unterstützt werden. 2. Die React -Community ist in Bezug auf Unternehmensanwendungen mit einem starken Ökosystem voreingenommen und unterstützt von Facebook und seiner Community und hat häufige Aktualisierungen.

Netflix verwendet React, um die Benutzererfahrung zu verbessern. 1) Die komponentierten Merkmale von React unterstützen die Netflix -Komplex -Benutzeroberfläche in überschaubare Module. 2) Virtual DOM optimiert UI -Updates und verbessert die Leistung. 3) Die Kombination von Redux und GraphQL verwaltet Netflix den Anwendungsstatus und den Datenfluss effizient.

Vue.js ist ein Front-End-Framework, und das Back-End-Framework wird verwendet, um die serverseitige Logik zu verarbeiten. 1) Vue.js konzentriert sich auf den Aufbau von Benutzeroberflächen und vereinfacht die Entwicklung durch komponentierte und reaktionsschnelle Datenbindung. 2) Back-End-Frameworks wie Express- und Django-HTTP-Anforderungen, Datenbankvorgänge und Geschäftslogik und auf dem Server ausgeführt.

Vue.js ist eng in den Front-End-Technologie-Stack integriert, um die Entwicklungseffizienz und die Benutzererfahrung zu verbessern. 1) Konstruktionstools: Integrieren Sie sich in Webpack und Rollup, um eine modulare Entwicklung zu erzielen. 2) Staatsmanagement: Integrieren Sie sich in Vuex, um den komplexen Anwendungsstatus zu verwalten. 3) Routing: Integrieren Sie sich in Vuerouter, um einseitige Anwendungsrouting zu realisieren. 4) CSS -Präprozessor: Unterstützt SASS und weniger, um die Stilentwicklungseffizienz zu verbessern.


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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

Dreamweaver CS6
Visuelle Webentwicklungstools

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool
