Diferencias

Muestra las diferencias entre dos versiones de la página.

Enlace a la vista de comparación

unidades:02_angular:07_nghide [2014/07/15 19:09]
admin
unidades:02_angular:07_nghide [2014/08/29 20:25] (actual)
admin
Línea 1: Línea 1:
 ====== 2.7 Directiva ng-hide ====== ====== 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 ​en función de cualquier valor del $scope y por lo tanto de nuestro modelo. Es la opuesta a la directiva [[unidades:​02_angular:​05_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''​.+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:​05_ngshow|ng-show]] pero al revés.+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 ===== ===== Expresión de la directiva =====
Línea 8: Línea 8:
  
 <note tip> <note tip>
-Recuerda que una referencia completa de que se puede poner como expresión está en {{:​unidades:​02_angular:​angular_expressions_cheatsheet.pdf|}}+Recuerda que una referencia completa de lo que se puede poner como expresión está en {{:​unidades:​02_angular:​angular_expressions_cheatsheet.pdf|}}
 </​note>​ </​note>​
 ===== Reglas de negocio del Interfaz de usuario ===== ===== 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 solo 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.+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 ''<​input>'':​
 +<sxh html>
 +<input ng-show="​seguro.sexo==='​M'"​ id="​fecundacionInVitro"​ name="​fecundacionInVitro"​ type="​checkbox"​ ng-model="​seguro.coberturas.fecundacionInVitro"​ />
 +</​sxh>​
 +
 +La condición para mostrar el elemento era:
 +<sxh js>
 +seguro.sexo==='​M'​
 +</​sxh>​
 +
 +Si usáramos ''​ng-hide''​ quedaría de la siguiente forma:
 +<sxh html>
 +<input ng-hide="​seguro.sexo!=='​M'"​ id="​fecundacionInVitro"​ name="​fecundacionInVitro"​ type="​checkbox"​ ng-model="​seguro.coberturas.fecundacionInVitro"​ />
 +</​sxh>​
 +
 +La condición para ocultar el elemento quedaría entonces:
 +<sxh js>
 +seguro.sexo!=='​M'​
 +</​sxh>​
 +
 +Personalmente siempre me gustan más las condiciones con  "​==="​ que con "​!=="​ , ya que creo que un programador las entiende mejor.
 +
 +<note tip>
 +Usa ''​ng-show''​ o ''​ng-hide''​ de forma que la expresión resultante sea la mas sencilla de entender por parte de otra persona.
 +</​note>​
  
 ===== Referencias ===== ===== Referencias =====
   * [[https://​docs.angularjs.org/​api/​ng/​directive/​ngHide|ngHide]]   * [[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}}   * {{:​unidades:​02_angular:​angular_expressions_cheatsheet.pdf|AngularJS Expressions}}
- 
unidades/02_angular/07_nghide.1405444174.txt.gz · Última modificación: 2014/07/15 19:09 por admin
Ir hasta arriba
CC Attribution-Share Alike 3.0 Unported
chimeric.de = chi`s home Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0