¿Por qué usar una clase? Porque facilita el trabajo, suponiendo que sepa cómo hacer una programación orientada a objetos y suponiendo que está escribiendo una GUI no trivial. El uso de objetos le permite dividir fácilmente su código en unidades modulares que son autónomas, y modularizar su código generalmente se considera una práctica recomendada.
La programación de la GUI se presta fácilmente a un estilo orientado a objetos, ya que una GUI está compuesta completamente de objetos: etiquetas, botones, barras de desplazamiento, áreas de texto, etc. Como ya está usando objetos, organizar su código en objetos más grandes tiene sentido . La barra de herramientas es un objeto, la barra de estado es un objeto, el panel de navegación es un objeto, el área principal es un objeto, cada pestaña del cuaderno es un objeto, etc.
Incluso cuando su código no es muy complejo, desde un punto de vista más práctico, le permite definir enlaces y devoluciones de llamada antes en el archivo que la definición de la función que está llamando, lo que creo que tiene mucho sentido.
Por ejemplo, considere un ejemplo simple (suponiendo que tkinter se haya importado como import tkinter as tk
(python3) o import Tkinter as tk
(python2):
def quit(event=None):
sys.exit()
root = tk.Tk()
label = tk.Label(root, text="Hello, world")
label.pack()
label.bind("<1>", quit)
root.mainloop()
Para mí, el flujo de ese código está todo mal. Tengo que definir el método de salida antes de hacer referencia a él, y la creación de la ventana raíz y la llamada al mainloop están separadas por el resto del código.
Al usar clases, sin embargo, puedo escribir el código en un orden más natural:
class MyWindow(tk.Frame):
def __init__(self, parent):
tk.Frame.__init__(self, parent)
label = tk.Label(self, text="Hello, world")
label.pack()
label.bind("<1>", self.quit)
def quit(self, event=None):
sys.exit()
root = tk.Tk()
MyWindow(root).pack()
root.mainloop()
El cuerpo principal de la GUI está justo en la parte superior del archivo, y el código de soporte está debajo de él. Ahora, por supuesto, puede usar funciones para lograr casi lo mismo. Sin embargo, en mi opinión, las clases hacen que todo sea un poco más fácil.
Otra ventaja es que ahora puedo cambiar fácilmente la ventana que contiene sin tener que cambiar nada de la ventana "principal" (y viceversa). Es decir, puedo agregar bordes o una nueva sección completa a la GUI principal, pero no tengo que tocar una sola línea de código dentro de MyWindow. Compare eso con el código de procedimiento donde podría tener que cambiar la label.pack()
declaración y las declaraciones del paquete (o cuadrícula) de todos los otros widgets en la interfaz de usuario.
Sin embargo, dicho todo esto, no es necesario utilizar un enfoque orientado a objetos para escribir un código bueno, limpio y fácil de mantener. Se puede ser, pero también puede conducir a la mala código. Al final del día, un enfoque orientado a objetos es solo una herramienta. Si lo usa o no, y si lo usa correctamente o no depende de muchos factores. Por lo tanto, puede ser que para usted, y para el código que escriba, un estilo funcional sea perfectamente aceptable. Creo que descubrirá que a medida que sus programas se vuelven más complejos, un enfoque orientado a objetos facilitará la organización y el mantenimiento de su código.