एक तरीका यह है कि फ्रेम को एक दूसरे के ऊपर रखा जाए, तो आप बस स्टैकिंग क्रम में एक के ऊपर एक उठा सकते हैं। ऊपर वाला वही होगा जो दिखाई दे रहा है। यह सबसे अच्छा काम करता है यदि सभी फ्रेम समान आकार के हों, लेकिन थोड़े से काम के साथ आप इसे किसी भी आकार के फ्रेम के साथ काम कर सकते हैं।
नोट : इसके लिए काम करने के लिए, किसी पृष्ठ के सभी विजेट में वह पृष्ठ (यानी self
:) या माता-पिता (या स्वामी, आपके द्वारा पसंद की गई शब्दावली के आधार पर) के वंशज होना चाहिए ।
आपको सामान्य अवधारणा दिखाने के लिए एक संक्षिप्त उदाहरण दिया गया है:
try:
import tkinter as tk
from tkinter import font as tkfont
except ImportError:
import Tkinter as tk
import tkFont as tkfont
class SampleApp(tk.Tk):
def __init__(self, *args, **kwargs):
tk.Tk.__init__(self, *args, **kwargs)
self.title_font = tkfont.Font(family='Helvetica', size=18, weight="bold", slant="italic")
container = tk.Frame(self)
container.pack(side="top", fill="both", expand=True)
container.grid_rowconfigure(0, weight=1)
container.grid_columnconfigure(0, weight=1)
self.frames = {}
for F in (StartPage, PageOne, PageTwo):
page_name = F.__name__
frame = F(parent=container, controller=self)
self.frames[page_name] = frame
frame.grid(row=0, column=0, sticky="nsew")
self.show_frame("StartPage")
def show_frame(self, page_name):
'''Show a frame for the given page name'''
frame = self.frames[page_name]
frame.tkraise()
class StartPage(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
self.controller = controller
label = tk.Label(self, text="This is the start page", font=controller.title_font)
label.pack(side="top", fill="x", pady=10)
button1 = tk.Button(self, text="Go to Page One",
command=lambda: controller.show_frame("PageOne"))
button2 = tk.Button(self, text="Go to Page Two",
command=lambda: controller.show_frame("PageTwo"))
button1.pack()
button2.pack()
class PageOne(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
self.controller = controller
label = tk.Label(self, text="This is page 1", font=controller.title_font)
label.pack(side="top", fill="x", pady=10)
button = tk.Button(self, text="Go to the start page",
command=lambda: controller.show_frame("StartPage"))
button.pack()
class PageTwo(tk.Frame):
def __init__(self, parent, controller):
tk.Frame.__init__(self, parent)
self.controller = controller
label = tk.Label(self, text="This is page 2", font=controller.title_font)
label.pack(side="top", fill="x", pady=10)
button = tk.Button(self, text="Go to the start page",
command=lambda: controller.show_frame("StartPage"))
button.pack()
if __name__ == "__main__":
app = SampleApp()
app.mainloop()
यदि आपको भ्रमित करने वाले वर्ग में उदाहरण बनाने की अवधारणा मिलती है, या यदि निर्माण के दौरान अलग-अलग पृष्ठों को अलग-अलग तर्क की आवश्यकता होती है, तो आप स्पष्ट रूप से अलग-अलग वर्ग कह सकते हैं। लूप मुख्य रूप से उस बिंदु को चित्रित करने का कार्य करता है जो प्रत्येक वर्ग समान होता है।
उदाहरण के लिए, व्यक्तिगत रूप से कक्षाएं बनाने के लिए आप लूप को हटा सकते हैं (इसके for F in (StartPage, ...)
साथ:
self.frames["StartPage"] = StartPage(parent=container, controller=self)
self.frames["PageOne"] = PageOne(parent=container, controller=self)
self.frames["PageTwo"] = PageTwo(parent=container, controller=self)
self.frames["StartPage"].grid(row=0, column=0, sticky="nsew")
self.frames["PageOne"].grid(row=0, column=0, sticky="nsew")
self.frames["PageTwo"].grid(row=0, column=0, sticky="nsew")
समय के साथ लोगों ने इस कोड (या एक ऑनलाइन ट्यूटोरियल जिसने इस कोड की नकल की) का उपयोग करके अन्य प्रश्न पूछे हैं। आप इन सवालों के जवाब पढ़ना चाह सकते हैं: