• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

175
Vistas
Estoy tomando el texto escrito dentro de un campo de entrada para mostrarlo en un div, pero funciona como un código

Un campo de entrada donde el usuario escribirá lo que quiere mostrar

 <input type="text" class="input-text form-control" placeholder="Input Text"> <div id="paste"></div> //code to be pasted here

función keyup llamada cada vez que el usuario realiza cambios

 $("#input-text").keyup(function(){ $("#paste").append(`<div class="form-control">$(".input-text").value</div>`)})

Cuando escribo "<tagname Hello /tagname>" en el campo de entrada, no se muestra, sino que se implementa como un código HTML. ¿Cómo puedo corregir eso?

about 3 years ago · Juan Pablo Isaza
3 Respuestas
Responde la pregunta

0

Creo que tienes un error tipográfico aquí <div id="paste"> //falta una comilla doble

about 3 years ago · Juan Pablo Isaza Denunciar

0

Hay varios problemas con su código, debería ser:

 $("#paste").append('<div class="form-control">' + $(this).val() + '</div>')
  • Debería ser $("#input-text").val() no $("#input-text").value También puede cambiar $("#input-text").val() a $(this).val()
  • Debe envolver su html <div class="form-control">$("#input-text").value</div>}) también tiene un } que no debería estar allí.

Manifestación

 $("#input-text").keyup(function() { $("#paste").append('<div class="form-control">' + $("#input-text").val() + '</div>') })
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <input type="text" id="input-text" class="form-control" placeholder="Input Text"> <div id="paste"></div> //code to be pasted here

about 3 years ago · Juan Pablo Isaza Denunciar

0

Dejando a un lado todos los problemas tipográficos, su problema es que está utilizando .append con una cadena html completa.

Esto agregará html.

Si desea que lo que ingresa (por ejemplo, etiquetas html) aparezca como texto, debe usar .text(newtext) . Mientras envuelve la entrada en un div, la forma más fácil es generar el div y luego agregar el texto. También puede codificar el texto cuando lo agrega como html, pero usar .text(txt) lo hace por usted.

 var div = $('<div class="form-control">'); div.text($(this).val()) $("#paste").append(div);

Puede convertir esto en una sola línea usando .appendTo() , que devuelve el nuevo elemento en lugar de .append() que devuelve el elemento externo, luego .text() .

 $("#input-text").keyup(function() { $('<div class="form-control">').appendTo("#paste").text( $(this).val() ); })
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <input type="text" id="input-text" class="form-control" placeholder="Input Text"> <div id="paste"></div> //code to be pasted here

about 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda