====== 2.7 Directiva ng-hide ====== La directiva ''ng-hide'' permite que un elemento de la página se haga invisible o visible en función de cualquier valor del $scope y por lo tanto de nuestro modelo. Es la opuesta a la directiva [[unidades:02_angular:06_ngshow|ng-show]] pero lo que hace es ocultar el elemento si la expresión es ''true'' o hacerlo visible si la expresión es ''false''. En este caso no vamos a poner un ejemplo ya que funciona como la directiva [[unidades:02_angular:06_ngshow|ng-show]] pero al revés. ===== Expresión de la directiva ===== La expresión que se puede poner en la directiva es del mismo tipo que [[unidades:02_angular:05_ngdisabled&#expresion_de_la_directiva|la expresión de la directiva ng-disabled]] Recuerda que una referencia completa de lo que se puede poner como expresión está en {{:unidades:02_angular:angular_expressions_cheatsheet.pdf|}} ===== Reglas de negocio del Interfaz de usuario ===== Al igual que con [[unidades:02_angular:05_ngdisabled#reglas_de_negocio_del_interfaz_de_usuario|las reglas de negocio del interfaz de usuario de ng-disabled]] debemos pensar que ahora sólo es necesario indicar cada regla de negocio de interfaz de usuario una única vez y AngularJS llamará a dicha regla cada vez que se modifiquen los datos de los que depende. ===== ng-show o ng-hide ===== Aunque tampoco es muy importante usar uno u otro , sí que viene bien decir cuándo usar ''ng-show'' o ''ng-hide'' por coherencia en el proyecto. Mi recomendación es usar el contrario a lo que ocurre por defecto. Me voy a explicar: Si inicialmente o lo normal es que el tag esté visible y lo que queremos es que se haga invisible cuando ocurra cierta condición, mi recomendación entonces es usar ''ng-hide'' ya que así estamos indicando que la regla/acción es ocultarlo cuando ocurre cierto evento pero que si no ocurriera estaría visible. El caso contrario sería que si inicialmente o por defecto el tag está oculto y lo que queremos es que se haga visible cuando ocurra cierta condición, mi recomendación entonces es usar ''ng-show'' ya que así estamos indicando que la regla/acción es mostrarlo cuando ocurre cierto evento pero que si no ocurriera estaría invisible. Otro caso que suele pasar es que realmente no hay una acción que muestre u oculte el elemento sino que en función del estado de otro campo esté o no visible. En ese caso no tiene sentido preguntarse por el concepto de //normal// o //inicialmente//. En este último caso lo mejor es usar el que evite una condición negativa que siempre es un poco más difícil de entender. Veamos un ejemplo de esto último: En nuestro ejemplo anterior de ''ng-show'' teníamos el siguiente tag '''': La condición para mostrar el elemento era: seguro.sexo==='M' Si usáramos ''ng-hide'' quedaría de la siguiente forma: La condición para ocultar el elemento quedaría entonces: seguro.sexo!=='M' Personalmente siempre me gustan más las condiciones con "===" que con "!==" , ya que creo que un programador las entiende mejor. Usa ''ng-show'' o ''ng-hide'' de forma que la expresión resultante sea la mas sencilla de entender por parte de otra persona. ===== Referencias ===== * [[https://docs.angularjs.org/api/ng/directive/ngHide|ngHide]] * [[https://docs.angularjs.org/guide/expression|Developer Guide / Expressions]] * {{:unidades:02_angular:angular_expressions_cheatsheet.pdf|AngularJS Expressions}}