En Frontend se usan un montón. Es muy común ver componentes que tienen una propiedad con múltiples valores y que tienen uno de esos valores por defecto
@daniel-peiro Жыл бұрын
Una variable o propiedad no nullable debería tener un valor siempre.
@cherrejim Жыл бұрын
Ya no 😂
@LuisDa20 Жыл бұрын
Me parece muy bien el contenido pero no hay ejemplos con frameworks de frontend, en react como harías para que una prop no tenga un valor por defecto ?
@inakiarias7465 Жыл бұрын
@@LuisDa20Ahora hay que especificar los valores por defecto para cada una de las 25 props que recibe un componente de libreria. Muy util la API!
@christophersierra3796 Жыл бұрын
Y porq era q no es bueno usarlos? Les falta ser mas concisos.
@juanpablodiazalbarracin7182 Жыл бұрын
ponga atención rey
@nivalderramas Жыл бұрын
Se mencionan varios puntos en el vídeo, son algo abstractos. En general a futuro genera problemas de mantenibilidad de código, por lo que si el modelo de datos o el caso de uso cambia será un pain in the ass acomodar todo el código para que siga funcionando y no se incluyan bug. Anyway: ponga atención x2 jaja
@YusufSalahAdDin Жыл бұрын
Pero es que no se entiende una...
@haroldcrow Жыл бұрын
Pero es qaue es mas sencillo que eso, antes de poner un valor por defecto hay que pensar, no solo sentarse a codificar, poner una fecha de nacimiento con la fecha actual como valor por defecto es un mal razonamiento del programador. Hay casos donde si pueden ir facilmente y otros en los que no, y ese razonamiento viene aun antes de sentarse a codificar. No hay que buscarle 3 patas al gato sabiendo que tiene 4...
@bagocavs Жыл бұрын
Si me parece que el ejemplo no es el mejor pero seria lo de menos, hace de cuenta que en vez de fecha de nacimiento es fecha de validacion o lo que sea.
@haroldcrow Жыл бұрын
@@bagocavsEl ejemplo es perfecto de hecho, porque permite ver como un valor por defecto debe razonarse antes de ponerlo. El ejemplo es tan absurdamente real. El tema aqui es que todo depende de lo que se decida ya sea como desarrollador individual o en equipo y documentarlo. Mas de si vale la pena o no usarlos.
@LuisFernandoAcosta-w7pАй бұрын
@@haroldcrow Concuerdo contigo, un valor por defecto debería prestarse bien para todos los casos, no solo casos donde "viene bien" y otros donde "venga mal", y eso ocurre justamente pensandolo bien antes de picar código, como comentas. Pero justamente me he dado cuenta de que si una herramiente le permite fallar al programador, va a fallar. Creo que ellos se refieren a programar de una manera más defensiva.
@Lanzelord Жыл бұрын
Creo que en este video no se explicó muy bien lo de los valores por defecto, y el ejemplo no ayuda, porque el valor por defecto que tiene es un tanto incongruente
@thekingwars Жыл бұрын
Una opcion para poder hacer resolver eso aunque ellos lo dicen es creando un 3er constructor, pero existe otras que son los famoso mappers o mapeadores, es basicamente una clase que tu creas llamese UserMapper donde creas un metodo abstracto y ahi te encargas de retornar una instancia de esa la clase principal llamese User y ahi haces las respectivas validaciones o valores por defecto en caso de que llegue null o no el valor deseado.
@davemour Жыл бұрын
A veces la necesidad de usar parámetros con valor por defecto te hace plantearte quién debería ser el cliente de tu clase y si esa es su responsabilidad.
@cmariuss Жыл бұрын
Si y de hecho hace poco lo use para un metodo de filtros en un repositorio. Entonces, pensaba si esto lo evitaria con el patron criteria
@nivalderramas Жыл бұрын
Muy interesante discusión, me ayuda un montón. gracias!
@CharlesDv Жыл бұрын
La mejor frase: "Sensación de productividad. Done" jajaja
@Tuligarnio11 ай бұрын
Es cierto que un parámetro por defecto puede ser peligroso como se muestra en el ejemplo del vídeo, pero creo que es necesario explicarlo más en detalle. En este caso concreto es malo, y es así porque el valor por defecto se encuentra en una clase de datos, su único propósito es ser un contendor de valores, por eso no tiene sentido que tenga valor por defecto, ya que los valores deberían venir de alguna base de datos o de algún formulario cuando se vaya a crear una instancia para almacenarla almacenar. Pero en otros casos como clases que proveen algún tipo de funcionalidad o incluso funciones puede ser muy útil ya que en muchas ocasiones los valores que utilizamos en la mayoría de parámetros son siempre los mismos y tener que estar estableciendo cada valor de todos los parámetros siempre sería muy tedioso y repetitivo.
@victorhugotiradopenaranda314910 ай бұрын
Vine a ver por qué no debería usar valores por defecto y de paso aprendí por qué no usar el constructor por defecto
@dcloki789 Жыл бұрын
muchas gracias
@_andres.hg_ Жыл бұрын
cual es el nombre de la fuente ?
@MsSoldadoRaso Жыл бұрын
Dank mono
@albertodimentico2 ай бұрын
El constructor solo se va a llamar al new del contructor desde, cuando recupero de la base de datos. Nunca en nuestros casos de uso vamos a llamarlo desde el contructor. Ejemplo no entendi.
@daniel-peiro Жыл бұрын
😢😢C# te obliga a inicializar valores por defecto si no son nullables.
@canodev Жыл бұрын
Para eso son los constructores
@bagocavs Жыл бұрын
Nop lo que hace C# es que te advierte que puede haber incongruencias con una propiedad que no se inicializa en el constructor
@daniel-peiro Жыл бұрын
@@bagocavs y advertirte no es obligar? En C# las variables y propiedades que no sean nullables deben ser inicializadas si o si.
@CoffeeToCode11 Жыл бұрын
En realidad esa validación se puede desactivar
@LuisFernandoAcosta-w7pАй бұрын
Para los que no entendieron. Esta es mi interpretación del video: Un valor por defecto puede tener múltiples interpretaciones desde el punto de vista del negocio. ¿El parámetro no se estableció porque no se necesita? ¿El parámetro lo estableció el cliente? ¿Por qué ese es el valor por defecto? ¿El valor por defecto podría cambiar en el tiempo (rompiendo todos los posibles usos actuales)? El video se refiere a exponer ÚNICAMENTE la API necesaria a los clientes para crear instancias con un estado válido y consistente para el negocio, sin ocultar a simple vista del lector reglas de negocio "implícitas", que en la práctica se traducen a que solo el señor de 80 años de la empresa sabe qué significa ese valor por defecto y por eso no lo pueden jubilar. Yo no los satanizaría, pero sí sería muy, muy, muy precabido al usarlos, pero aquí hablan de proyectos donde chorrocientasmil personas meterán mano y donde es mejor no delegar a "su criterio" este tipo de cosas porque algunos pueden estar más preparados que otros, entonces optan por bloquear totalmente esta herramienta del lenguaje en cuestión, ya sea por convención de equipo o usando linters.
@cherrejim Жыл бұрын
Geniales como siempre
@alexandercasas5779 ай бұрын
Básicamente no usar valores por defecto porque no confían en su propio criterio para establecerlos correctamente. Me parece bien, los que no son capaces de utilizar una herramienta sin hacer desastres no deberían usarla. Por otro lado, los que si pueden sacarle el jugo a esas cosas pues deberían usarlas con confianza
@litox9 Жыл бұрын
Muy bien, pero deberíais plantear también eliminar esos metodos estáticos "create", ocultan las dependencias reales y evitan que se usen los value objects por toda la base de código. Nada como un buen y explicito "new".
@bagocavs Жыл бұрын
Porque? no oculta ninguna dependencia "real", solo muestra lo que es escencial para el cliente y encapsula lo que no. Ademas lo de evitar el uso de value objects yo lo veo como un beneficio, delegas su creacion a esta clase y te olvidas
@litox9 Жыл бұрын
@@bagocavspor ejemplo si el string de email no es una dirección válida dónde deberíamos controlar ese error? En su value object UserEmail si no queremos incumplir SRP, creamos un metodo isValid() y comprobamos antes de pasarlo al new User(). Si metemos todo esto en User también estamos incumpliendo SRP, según yo lo veo. Al final si tienes una dependencia entre User y UserEmail no está de más que el "cliente" lo sepa para que pueda adaptarse a cualquier casuística, no sé si me explico... Otro beneficio de extraer los value objects es poder hacer refactoring con ellos y reutilizar código.
@christianricardo4058 Жыл бұрын
Es un static factory, so...
@alejandroarzolasaavedra9821 Жыл бұрын
se entiende la idea, pero la verdad que lo habeis explicado un poco mal, y mucho desvario por las ramas pero bueno esta bien el video.
@JorgeLlorca-b2d Жыл бұрын
Me hace gracia que les chirrie un valor por defecto pero luego no chirrie usar parametros en lugar de un parametro con un type/clase/interfaz/... ¿Que vas a hacer cuando tu clase en lugar de ser un caso raro de 2 propiedades como son email y birtdate tengas 10-15-25 propiedades?
@CodelyTV Жыл бұрын
Dividirla 😬
@JorgeLlorca-b2d Жыл бұрын
@@CodelyTV Dividir pòr dividir creo que trae mas problemas que beneficios, por ejemplo un Pedido tiene información de metodos de pago, pago escogido , transportista escogido , cupones, info del producto en el momento que se hizo el pedido, totalizaciones, tasas, estados, información del cliente como el grupo al que pertenecia y el tipo de descuento que tenga ese grupo, por si cambia de b2c a b2b o de silver a platinum o lo que sea, etc... Eso es una barbaridad de información y hasta cierto punto lo puedes dividir para tener bien estructurado el dato, pero el problema sigue estando ahi, mucho dato. Puedes sacar ciertas cosas fuera del pedido, como etiquetas de transportista, información que te den las distintas plataformas de metodos de pago, los "intents", el carrito, información de ERP, información de SGA, shippings (nosotros estamos integrados con 24 empresas de transporte distintas, tu compras con un transportista genérico y lo enviamos de modo que haya un equilibrio y no nos cueste una pasta pero tampoco tarde en llegarte, de modo que puede hacerse en 2 viajes si fuese necesario, etc... porque sirven para "gestionar" la creación del pedido o para complementarlo una vez hecho pero no forman parte del pedido como tal. ¿Que haces 80 métodos estáticos para poner cada campo uno a uno? Desde mi punto de vista un pedido es solo una materialización del carrito, coge lo que hay en el carrito, añade información extra del sistema (porque el nombre del transportista, producto, etc... podria cambiar y tu tienes que tener la foto de lo que pidio el tio, no de lo que hay en el sistema), calcula y guarda, no le veo beneficio alguno a tener un metodo con 80 campos uno detrás de otro ni le veo sentido a tener 80 metodos estáticos. No lo digo en plan para criticar ni atacaros, pero estaria bien que alguna vez pusieseis de ejemplo un caso de uso tocho.
@JoseManuel-lo2ed10 ай бұрын
Sois unos frikis, pero muy simpáticos.
@imsergiohere Жыл бұрын
Muy mal ejemplo. Efectivamente ahí es mala idea. Pero el programador NO PUEDE ser tan idiota de poner un birthday por defecto. El problema puede ser una falta de actitud, no un "antipatrón"
@imsergiohere Жыл бұрын
Un mejor ejemplo: class Log. ¿Es un antipatrón poner timestamp por defecto? Yo diría que no, pero puedo entender de que si se trata de sistemas distribuidos, quizá lo mejor es obligar a pasar el atributo.