Muestra las diferencias entre dos versiones de la página.
Ambos lados, revisión anterior Revisión previa Próxima revisión | Revisión previa | ||
clase:daw:diw:2eval:tema07 [2021/01/06 11:54] admin |
clase:daw:diw:2eval:tema07 [2021/01/06 12:48] (actual) admin [Ejercicios] |
||
---|---|---|---|
Línea 1: | Línea 1: | ||
====== 7. Drag & Drop ====== | ====== 7. Drag & Drop ====== | ||
+ | El drag & drop es una forma de simplificar los interfaces de usuario. | ||
- | * Drag & Drop | ||
- | * [[https:// | ||
- | * [[http:// | ||
- | * [[http:// | + | En el drag & drop siempre hay 2 elementos |
+ | * El elemento que se arrastra | ||
+ | * El elemento donde se suelta | ||
+ | Respecto a los eventos , hay 3 eventos en un drag & drop: | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | |||
+ | Por último está: | ||
+ | * La propiedad '' | ||
+ | * El objeto de JavaScript '' | ||
+ | |||
+ | Mas información: | ||
+ | * [[http:// | ||
+ | * [[https:// | ||
+ | * [[http:// | ||
===== API ===== | ===== API ===== | ||
Línea 23: | Línea 36: | ||
</ | </ | ||
< | < | ||
- | function onDragOver(ev) { | ||
- | ev.preventDefault(); | ||
- | } | ||
function onDragStart(ev) { | function onDragStart(ev) { | ||
Línea 31: | Línea 41: | ||
var data=element.innerText; | var data=element.innerText; | ||
- | ev.dataTransfer.setData(" | + | ev.dataTransfer.setData(" |
} | } | ||
+ | |||
function onDrop(ev) { | function onDrop(ev) { | ||
Línea 38: | Línea 49: | ||
var element=ev.target; | var element=ev.target; | ||
- | var data = ev.dataTransfer.getData(" | + | var data = ev.dataTransfer.getData(" |
element.innerText=data; | element.innerText=data; | ||
} | } | ||
+ | | ||
+ | function onDragOver(ev) { | ||
+ | ev.preventDefault(); | ||
+ | } | ||
</ | </ | ||
</ | </ | ||
< | < | ||
- | < | + | < |
<p class=" | <p class=" | ||
- | <br> | ||
<ul> | <ul> | ||
Línea 63: | Línea 76: | ||
</ | </ | ||
+ | * Atributo '' | ||
+ | * Evento '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * Evento '' | ||
+ | * Evento '' | ||
+ | * '' | ||
+ | * '' | ||
+ | |||
+ | ===== dataTransfer ===== | ||
+ | El objeto '' | ||
+ | |||
+ | |||
+ | Para guardar el dato, se usa: | ||
+ | ev.dataTransfer.setData(" | ||
+ | Para obtener el dato, se usa: | ||
+ | var data = ev.dataTransfer.getData(" | ||
+ | | ||
+ | | ||
+ | Sin embargo , podemos pensar que no es muy útil ya que se podría usar directamente una variable de JavaScript. En ese caso vamos a usar una variable global llamada '' | ||
+ | |||
+ | <sxh javascript> | ||
+ | var dragData=""; | ||
+ | |||
+ | function onDragOver(ev) { | ||
+ | ev.preventDefault(); | ||
+ | } | ||
+ | |||
+ | function onDragStart(ev) { | ||
+ | var element=ev.target; | ||
+ | dragData=element.innerText; | ||
+ | } | ||
+ | |||
+ | function onDrop(ev) { | ||
+ | ev.preventDefault(); | ||
+ | |||
+ | var element=ev.target; | ||
+ | |||
+ | element.innerText=dragData; | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | |||
+ | ¿cual es la diferencia entre usar '' | ||
+ | |||
+ | Sin embargo la ventaja de usar la variable es que podemos almacenar mas cosas que un simple texto. | ||
Línea 68: | Línea 127: | ||
===== Ejercicios ===== | ===== Ejercicios ===== | ||
+ | ==== Ejercicio 1 ==== | ||
+ | En base al ejemplo del tema, prueba a arrastrar el texto a otra aplicación como el Bloc de Notas de Windows. ¿Ha funcionado? | ||
- | ==== Ejercicio 5 ==== | + | Ahora modifica el ejemplo y en vez de usar '' |
- | Crea un programa | + | |
- | En la parte superior estarán las 4 imágenes del puzzle sin colocar. | + | |
- | En la parte imferior, habrá un cuadro con los 4 huecos a colocar. | + | |
- | Separa todo lo que puedas la parte visual de la lógica del puzzle | ||
- | Para ello crea una clase Puzzle | + | ==== Ejercicio 2 ==== |
+ | En base al ejemplo del tema, modifica | ||
+ | <sxh json> | ||
+ | { | ||
+ | color: "# | ||
+ | texto: "Disco duro" | ||
+ | } | ||
+ | </ | ||
- | ==== Ejercicio 6 ==== | + | Y al soltar que en el elemento ''< |
- | {{ : | ||
+ | ==== Ejercicio 3 ==== | ||
+ | Haz un programa similar al siguiente: | ||
+ | {{: | ||
+ | |||
+ | De forma que: | ||
* Al arrastrar el icono de " | * Al arrastrar el icono de " | ||
* Al arrastrar el icono de " | * Al arrastrar el icono de " | ||
Línea 88: | Línea 156: | ||
* Al arrastrar el icono de "Nº de Vuelos Aterrizados" | * Al arrastrar el icono de "Nº de Vuelos Aterrizados" | ||
- | {{: | + | Ademas, cambiar todo el aspecto visual para que "quede bonito" |
- | + | ||