Diferencia entre revisiones de «DRUPAL Módulo View»

De MediaWiki
Ir a la navegación Ir a la búsqueda
Línea 29: Línea 29:
 
* Vexamos un exemplo.
 
* Vexamos un exemplo.
  
=== Exemplo ===
+
=== Caso Práctico ===
  
 
* Imaxinemos que temos unha tenda de ordenadores e vendemos compoñentes do mesmo.  
 
* Imaxinemos que temos unha tenda de ordenadores e vendemos compoñentes do mesmo.  
Línea 71: Línea 71:
 
Image:Drupal_modulos_view_16.jpg| Se prememos sobre un tipo de produto aparecerá a táboa anterior pero só cos datos do tipo seleccionado.
 
Image:Drupal_modulos_view_16.jpg| Se prememos sobre un tipo de produto aparecerá a táboa anterior pero só cos datos do tipo seleccionado.
 
</gallery>
 
</gallery>
 
  
 
== Relacións ==
 
== Relacións ==

Revisión del 22:12 14 sep 2016

Introdución

  • Porqué é tan importante este módulo ? Con este módulo imos poder facer 'consultas' á base de datos de Drupal (onde se gardan todos os contidos) e crear un novo contido a partires de dita consulta.
  • Imos poder determinar:
  • O orixe de datos de onde obtemos a información.
  • Os campos que conforman a consulta.
  • As condicións que queremos que cumpran os campos para entrar na vista.
  • Podemos engadir criterios de ordenación.
  • Por exemplo:
  • Imaxinemos que temos un sitio web de traballos. Cun view podemos obter unha nova páxina que obteña os traballos dunha categoría determinada e que os amose nunha táboa de forma ordenada por data.
  • Imaxinemos que temos un sitio web de produtos e queremos crear unha páxina na que se amose en forma de Grid os produtos dun tipo determinado. Queremos que cada produto do grid amose o seu nome e prezo e que cando se preme sobre o nome vaiamos á páxina do produto. Queremos que o grid sexa 3x3 e con paxinación.
  • Como vemos os Views van permitirnos facer consultas como se fixeramos consultas SQL contra unha base de datos, pero non só vai devolver os contidos, se non que vai a establecer un formato de presentación deses contidos (con filtrado e ordeación) e o resultado vai poder ser unha páxina, un bloque para poñer nalgunha sección do Theme,...

Paso de parámetros a unha vista

  • NOTA: Esta sección está asociada á realización dun EXERCICIO.



  • Pode suceder que teñamos unha vista con datos dun tipo determinado e queiramos que ditos datos aparezan filtrados por un campo da vista, de tal forma que apareza previamente un resumo có número de elementos que teñen un valor determinado para ese campo, e que ao premer aparezan a lista de elementos da vista que teñan ese dato.
  • Vexamos un exemplo.

Caso Práctico

  • Imaxinemos que temos unha tenda de ordenadores e vendemos compoñentes do mesmo.
  • A vista de nome produtos_informaticos ten os seguintes campos:
  • nome
  • prezo
  • tipo, sendo tipo unha lista cos seguintes valores: CPU, Memoria, Hard Disk.


  • Unha vez engadidos, crearemos unha vista en forma de táboa para que amose os produtos. Polo tanto iremos a Administrar => Estructura => Vistas e crearemos unha nova vista.


NOTA IMPORTANTE: Fixarse como DRUPAL envía os datos dos parámetros na URL. Así se escollo CPU a url terá este aspecto: http://localhost/drupal/lista-de-produtos-informaticos/cpu


  • O que imos facer agora é que se nos amose unha lista de 'tipos de produto' có número de produtos de cada tipo e que ao premer aparece unha táboa como a anterior pero só do tipo de produto seleccionado. Polo tanto é como se pasáramos un parámetro á vista para que escolla os dun tipo. Vería a ser a parte where dunha sentenza SQL.

Relacións

  • Pode suceder que necesitemos relacionar un tipo de contido con outro para crear unha vista no que haia campos dos dous contidos.
  • Para que isto sexa correcto normalmente teremos que ter algunha relación entre os dous tipos de contido.
  • Nota: Isto sería o equivalente a facer un JOIN en SQL (relacionamos dúas táboas a través das súas claves primaria-foránea).
  • Por exemplo, pode ter un tipo de contido no que gardo información sobre Coches que se gardan nun garaxe. Cada coche está 'relacionado' co seu dono. Por outra banda teño os donos cos seus datos (teléfono, dirección,...). Cando dou de alta un coche, asocio dito coche a un dono, escollendo o dono,por exemplo, dunha lista (isto xa o fixemos no punto anterior).
Pero resulta que necesito unha vista na que aparezan de vez os datos do coche xunto co nome e teléfono do dono, sen ter que premer sobre o dono para que me amose dito dato.
Necesitamos por tanto 'relacionar' o coche cos donos dentro da vista, e a relación a faremos por medio do identificar do dono, xa que este se atopa nos dous tipos de contidos.
  • Vexamos un exemplo.

Relacións

  • Imaxinemos que temos dous tipos de contido:
  • Tipo de contido: Profesores do Centro (cos seguintes campos)
  • Titulo (aparece cando se crea o tipo de contido)
  • Nome
  • Foto (se lle aplica un filtro para reducir o seu tamaño a 260x260)
  • Campo comentarios
Todos os campos son obrigatorios.
  • Tipo de contido: Módulos do Centro (cos seguintes campos)
  • Titulo (aparece cando se crea o tipo de contido)
  • Nome do Módulo: Texto sen formato.
  • Número de Horas: Número entero cun mínimo dunha hora.
  • Ciclo ao que pertence: Lista de selección cos seguintes datos: ASI, DAW e DAM. Só se pode seleccionar un. Se podería crear outro tipo de contido (Ciclos) e crear unha referencia a dito tipo.
  • Profesor que imparte: fai referencia a entidade 'Profesor do Centro' creado antes.
Todos os campos son obrigatorios.
  • Este último campo é o que nos vai servir de 'enlace' entre o tipo 'Profesores do Centro' e 'Módulos do Centro'.





-- Ángel D. Fernández González -- (2016).