• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

240
Views
Quiero obtener el contenido del archivo por elemento img no es asíncrono (src es svg)

Tengo un elemento img, su atributo src es un archivo url svg.
Puedo obtener este elemento img dom, pero quiero obtener el contenido de este archivo y no puedo usar ajax.
¡Gracias! ejemplo:

 <svg> <rect> </rect> </svg>

este es mi codigo

 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <img id="testImg" src="logo.svg" alt=""> <script> const img = document.getElementById('testImg'); console.log('img', [img]); </script> </body> </html>

¡Esta es mi escena! No puedo usar ajax porque no puedo obtener los datos de la configuración asíncrona de 'ondragstart' en el evento 'ondrop'.

 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> </head> <body> <script src="https://unpkg.com/axios/dist/axios.min.js"></script> <img id="img" draggable="true" src="logo.png" width="50px" height="50px" /> <div id="div" style="background-color: #123; width: 400px; height: 300px;" ></div> <script> const img = document.getElementById('img'); img.addEventListener('dragstart', function(e) { const src = e.target.src; console.log(src); axios.get(src).then(function(res) { console.log(res.data); e.dataTransfer.setData('text/plain', res.data); }); }); const div = document.getElementById('div'); div.addEventListener('dragover', function(e) { e.preventDefault(); }); div.ondrop = function(e) { const data = e.dataTransfer.getData('text/plain'); console.log(data); }; </script> </body> </html>
about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Suponiendo que es la imagen SVG que ya se muestra la que debe arrastrarse y soltarse, este podría ser un ejemplo. Es solo la identificación de la imagen la que se "transfiere" y en el evento de caída, las imágenes se recuperan utilizando el atributo src.

En la devolución de llamada de la función de búsqueda, creo un documento XML y, en este caso, solo imprimo el elemento raíz en la consola.

En este ejemplo, uso un URI de datos para la fuente de las imágenes, pero esto puede ser reemplazado por su URL a su propia imagen.

 const img = document.getElementById('img'); img.addEventListener('dragstart', function(e) { const id = e.target.id; e.dataTransfer.setData('text/plain', id); }); const div = document.getElementById('div'); div.addEventListener('dragover', function(e) { e.preventDefault(); }); div.addEventListener('drop', function(e) { e.preventDefault(); const id = e.dataTransfer.getData('text/plain'); let img = document.getElementById(id); fetch(img.src).then(res => res.text()).then(text => { let parser = new DOMParser(); let svg = parser.parseFromString(text, "text/xml"); console.log(svg.rootElement.outerHTML); }); });
 <img id="img" draggable="true" src="" width="50px" height="50px"/> <div id="div" style="background-color: #123; width: 400px; height: 300px;"></div>

about 3 years ago · Juan Pablo Isaza Report

0

Dado su proyecto, parece que tendría mucho más sentido hacerlo al revés:

  • Obtener el recurso
  • Leerlo como texto
  • Cargue el recurso obtenido en las imágenes (como un blob: URL)

De esta manera, cuando comience a arrastrar sus elementos, ya tendrá su versión de marcado:

 const images = document.querySelectorAll("img[data-src]"); images.forEach( async (img) => { // we store the actual src in a data- attribute // we will only fetch it from here const resp = await fetch(img.getAttribute("data-src")); const as_blob = resp.ok && await resp.blob(); // read as text to get the markup const markup = await as_blob.text(); // create a blob: URL so we can display the image const url = URL.createObjectURL(as_blob); img.src = url; // once the image is loaded we can revoke the blob: URL // this will allow the Blob to be Garbage Collected img.addEventListener("load", (evt) => URL.revokeObjectURL(url), { once: true }); img.addEventListener("dragstart", (evt) => evt.dataTransfer.setData("text/plain", markup) ); }); const div = document.getElementById("div"); div.addEventListener("dragover", (evt) => evt.preventDefault() ); div.ondrop = (evt) => { const data = evt.dataTransfer.getData('text/plain'); console.log(data); };
 <img id="img" draggable="true" data-src="https://upload.wikimedia.org/wikipedia/commons/4/4a/Commons-logo.svg" width="50px" height="50px" /> <div id="div" style="background-color: #123; width: 400px; height: 300px;"></div>

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error