Heim >Web-Frontend >js-Tutorial >So verhindern Sie, dass „preventdefault()' wirksam wird
Methoden, um zu verhindern, dass default() wirksam wird: 1. Verwenden Sie den Ereignis-Proxy. Der Ereignis-Proxy ist eine Technologie, die Ereignis-Listener zu übergeordneten Elementen hinzufügt und dann durch Ereignis-Bubbling Ereignisse auf untergeordneten Elementen auslöst das Standardverhalten des Ereignisses auf dem Weg; 2. Flag-Variable Wenn Sie entscheiden müssen, ob das Standardverhalten des Ereignisses basierend auf Bedingungen im selben Event-Handler blockiert werden soll, müssen Sie eine Flag-Variable verwenden, um den Aufruf von zu steuern die Methode „preventDefault()“.
In Browsern wird die Methode „preventDefault()“ häufig verwendet, um das Standardverhalten von Ereignissen zu verhindern. Sie können diese Methode beispielsweise verwenden, wenn Sie das Verhalten beim Klicken auf einen Link oder beim Absenden eines Formulars anpassen möchten, anstatt den Browser das Standardnavigations- oder Formularübermittlungsverhalten ausführen zu lassen.
Wenn Sie jedoch verhindern möchten, dass die Methode „preventDefault()“ wirksam wird, müssen Sie möglicherweise einige komplexere Techniken verwenden, da JavaScript keine direkte Methode zum Rückgängigmachen oder Überschreiben des Verhaltens von „preventDefault()“ bereitstellt.
1. Event-Proxy verwenden
Event-Proxy ist eine Technologie, die Event-Listener zu übergeordneten Elementen hinzufügt und dann durch Event-Bubbling Ereignisse auf untergeordneten Elementen auslöst. Auf diese Weise können Sie das Standardverhalten des Ereignisses ändern oder verhindern, während es sprudelt.
Hier ist ein einfaches Beispiel:
document.body.addEventListener('click', function(event) { if (event.target.tagName === 'BUTTON' && event.target.textContent === 'Prevent Default') { event.stopPropagation(); // 阻止事件冒泡,从而阻止默认行为 } }); document.body.innerHTML = '<button>Prevent Default</button><div>Some content</div>';
In diesem Beispiel versucht der Browser, wenn Sie auf die Schaltfläche klicken, das Standardklickverhalten auszulösen (z. B. das Navigieren zu einem Link oder das Absenden eines Formulars). Da wir jedoch die Ausbreitung des Ereignisses blockierten, während es sprudelte, wurde das Standardverhalten nicht ausgelöst.
Diese Methode verhindert jedoch nicht das Standardverhalten von Ereignissen, für die die Methode „preventDefault()“ aufgerufen wurde. Da die Methode „preventDefault()“ im Event-Handler aufgerufen wird, wird das Ereignis blockiert, sobald der Event-Handler seine Ausführung beendet hat. Sie können dieses Ergebnis nicht mehr ändern, nachdem der Ereignishandler ausgeführt wurde.
2.Flag-Variable
Wenn Sie basierend auf Bedingungen im selben Event-Handler entscheiden müssen, ob das Standardverhalten des Ereignisses verhindert werden soll, müssen Sie möglicherweise eine Flag-Variable verwenden, um den Aufruf von präventDefault() zu steuern. Methode. Zum Beispiel:
var preventDefault = false; document.body.addEventListener('click', function(event) { if (event.target.tagName === 'BUTTON' && event.target.textContent === 'Prevent Default') { preventDefault = true; } else if (preventDefault) { event.preventDefault(); } }); document.body.innerHTML = '<button>Prevent Default</button><div>Some content</div>';
In diesem Beispiel wird die Variable „preventDefault“ auf „true“ gesetzt, wenn Sie auf die Schaltfläche klicken. Wenn der Ereignishandler dann andere Elemente verarbeitet, prüft er den Wert der Variable „preventDefault“ und ruft bei Bedarf die Methode „preventDefault()“ auf. Auf diese Weise können Sie das Standardverhalten des Ereignisses basierend auf Bedingungen innerhalb desselben Ereignishandlers verhindern.
Das obige ist der detaillierte Inhalt vonSo verhindern Sie, dass „preventdefault()' wirksam wird. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!