Heim  >  Artikel  >  Backend-Entwicklung  >  Wie können Sie benutzerdefinierten Code nach Textaktualisierungen im Text-Widget von Tkinter ausführen?

Wie können Sie benutzerdefinierten Code nach Textaktualisierungen im Text-Widget von Tkinter ausführen?

DDD
DDDOriginal
2024-11-03 20:03:29757Durchsuche

How can you execute custom code after text updates in Tkinter's Text widget?

Wie funktionieren Bindungen im Tkinter-Text-Widget?

Wenn Sie in Tkinter mit einem Text-Widget interagieren, lösen Ihre Tastenanschläge verknüpfte Bindungen aus mit dem Widget. Diese Bindungen bestimmen, wie der Text während der Eingabe aktualisiert wird. Es gibt jedoch Fälle, in denen Sie möglicherweise Ihren eigenen Code ausführen möchten, nachdem Textaktualisierungen über integrierte Klassenbindungen stattgefunden haben.

Hinter den Kulissen: Bind-Tags und Ereignisbehandlung

Tkinter verwendet Bind-Tags, um Ereignisse zu verarbeiten. Jedes Widget verfügt über ein Bind-Tag mit demselben Namen wie das Widget. Zu den weiteren Bind-Tags gehören die Klasse des Widgets, der Pfad des Stammfensters und das allgemeine Tag „all“. Widgets werden Bind-Tags zugewiesen, die Ereignisse der Reihe nach verarbeiten, beginnend mit dem spezifischsten (Widget) und endend mit dem am wenigsten spezifischen (alle).

Problem mit der Bindungsreihenfolge lösen

Um selbstdefinierte Ereignisse nach Klassenbindungen zu binden, haben Sie zwei Möglichkeiten: Bind-Tags neu anordnen oder ein neues Bind-Tag einführen.

Option 1: Bind-Tags neu anordnen

Durch Anpassen der Reihenfolge der Bindungs-Tags können Sie der Ereignisverarbeitung für Ihre benutzerdefinierten Bindungen Vorrang vor Klassenbindungen einräumen. Wenn Sie beispielsweise ein Bind-Tag haben, das das Widget darstellt („Eintrag1“ im Code unten), verschieben Sie es unter das Klassen-Bind-Tag („Eintrag“) in der Liste der Bind-Tags:

<code class="python">entry1.bindtags(('Entry', '.entry1', '.', 'all'))</code>

Option 2: Einführung eines neuen Bind-Tags

Alternativ können Sie ein zusätzliches Bind-Tag erstellen, das dem Klassen-Bind-Tag folgt. Ihre Bindungen werden dann an dieses neue Tag angehängt:

<code class="python">entry3.bindtags(('.entry3','Entry','post-class-bindings', '.', 'all'))

# Custom bindings are attached to the 'post-class-bindings' tag
entry3.bind_class("post-class-bindings", "<KeyPress>", OnKeyPress)</code>

Codebeispiel

Der folgende Code veranschaulicht die Verwendung dieser Techniken:

<code class="python">import Tkinter

def OnKeyPress(event):
    value = event.widget.get()
    string="value of %s is '%s'" % (event.widget._name, value)
    status.configure(text=string)

root = Tkinter.Tk()

entry1 = Tkinter.Entry(root, name="entry1")
entry2 = Tkinter.Entry(root, name="entry2")
entry3 = Tkinter.Entry(root, name="entry3")

entry1.bindtags(('.entry1', 'Entry', '.', 'all'))
entry2.bindtags(('Entry', '.entry2', '.', 'all'))
entry3.bindtags(('.entry3','Entry','post-class-bindings', '.', 'all'))

# Custom bindings are attached to the default tags
entry1.bind("<KeyPress>", OnKeyPress)

# Custom bindings are attached to the reordered tags
entry2.bind("<KeyPress>", OnKeyPress)

# Custom bindings are attached to the new 'post-class-bindings' tag
entry3.bind_class("post-class-bindings", "<KeyPress>", OnKeyPress)

root.mainloop()</code>

Wenn Sie diesen Code ausführen und Tasten in den drei Eintrags-Widgets drücken, werden Sie feststellen, dass die Bindungen für das erste Eintrags-Widget aufgrund der standardmäßigen Bindungsreihenfolge um ein Zeichen zurückliegen. Die Bindungen für die Widgets für den zweiten und dritten Eintrag aktualisieren den Text jedoch korrekt, während Sie tippen.

Das obige ist der detaillierte Inhalt vonWie können Sie benutzerdefinierten Code nach Textaktualisierungen im Text-Widget von Tkinter ausführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn