Tkinter 文字小部件中的綁定如何發揮作用?
在 Tkinter 中,當您與文字小部件互動時,您的按鍵會觸發關聯的綁定與小部件。這些綁定確定文字在您鍵入時如何更新。但是,在某些情況下,您可能希望在透過內建類別綁定進行文字更新後執行自己的程式碼。
幕後:綁定標籤和事件處理
Tkinter 利用綁定標籤來處理事件。每個小部件都有一個與小部件同名的綁定標籤,其他綁定標籤包括小部件的類別、根視窗的路徑和通用的「all」標籤。小部件被分配了按順序處理事件的綁定標籤,從最具體的(小部件)開始,到最不具體的(全部)結束。
解決綁定順序問題
要在類別綁定後綁定自訂事件,有兩種選擇:重新排序綁定標籤或引入新的綁定定標籤。
選項 1:重新排列綁定標籤
透過調整綁定標籤的順序,您可以將自訂綁定的事件處理優先於類別綁定。例如,如果您有一個表示小部件的綁定標籤(下方程式碼中的「entry1」),請將其移至綁定標籤清單中的類別綁定標籤(「Entry」)下方:
<code class="python">entry1.bindtags(('Entry', '.entry1', '.', 'all'))</code>
選項2:引入新的綁定標籤
或者,您可以在類別綁定標籤後面建立一個額外的綁定標籤。然後,您的綁定將附加到此新標籤:
<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>
程式碼範例
以下程式碼說明了這些技術的用法:
<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>
以下程式碼說明了這些技術的用法:
以下程式碼說明了這些技術的用法: 透過執行此程式碼並按下三個條目小部件中的按鍵,您會注意到由於預設的綁定順序,第一個條目小部件的綁定似乎落後了一個字元。但是,第二個和第三個條目小工具的綁定會在您鍵入時正確更新文字。以上是在 Tkinter 的文字小工具中文字更新後如何執行自訂程式碼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!