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

0

244
Views
JavaScript selecciona y resalta texto en 2 bloques al mismo tiempo en textarea y div

javascript seleccione y resalte el texto en uno de los bloques y resalte el texto al mismo tiempo en textarea y div

 <div id="preview"></div>

cuando seleccionas el texto en textarea

mi objetivo es cuando seleccionas texto en textarea o div block

mostrar el texto resaltado en ambos libros al mismo tiempo

esto es lo que hay que mirar

ingrese la descripción de la imagen aquí

aquí está mi código

 function showPreview() { var value = $('textarea').val().trim(); value = value.replace("<", "&lt;"); value = value.replace(">", "&gt;"); $('#preview').html(value); }
 ::-moz-selection { /* Code for Firefox */ color: red; background: yellow; } ::selection { color: red; background: yellow; } #preview { width:410px; border: solid 1px #999; padding:5px;}
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <textarea rows="10" cols="50" onInput="showPreview();"> product noun Save Word To save this word, you'll need to log in. Log In prod·​uct | \ ˈprä-(ˌ)dəkt \ Definition of product 1: the number or expression resulting from the multiplication together of two or more numbers or expressions 2a(1): something produced especially : COMMODITY sense 1 (2): something (such as a service) that is marketed or sold as a commodity b: something resulting from or necessarily following from a set of conditions a product of his environment 3: the amount, quantity, or total produced 4: CONJUNCTION sense 5 </textarea> <br/> <hr/> <div id="preview"> </div>

en este momento resalta solo cuando selecciona, necesita resaltar en ambos

gracias

over 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

 let textarea = document.querySelector('textarea'); let target = document.querySelector('#preview'); let plainLine = '\n'; let htmlLine = '<br/>'; let pressed = false; function textToHtml(text) { return text.replace(new RegExp(plainLine, 'g'), htmlLine).replace(/\s\s/g, '&nbsp;&nbsp;').replace(/^\s/g, '&nbsp;'); } function htmlToText(html) { html = html.replace(new RegExp(htmlLine, 'g'), plainLine); return $('<div>').html(html).text(); } function highlight(text, from, to) { let mark = text.slice(from, to); if (mark) mark = `<mark>${mark}</mark>`; return text.slice(0, from) + mark + text.slice(to); } function showPreview() { let from = textarea.selectionStart; let to = textarea.selectionEnd; let content = highlight(textarea.value, from, to); target.innerHTML = textToHtml(content); } $(textarea).on({ mousedown: () => pressed = true, mouseup: () => pressed = false, mousemove: () => pressed && showPreview(), click: () => showPreview(), blur: () => showPreview() }); showPreview();
 ::-moz-selection { /* Code for Firefox */ color: red; background: yellow; } ::selection { color: red; background: yellow; } #preview { width: 410px; border: solid 1px #999; padding: 5px; }
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <textarea rows="10" cols="50" onInput="showPreview();"> product noun Save Word To save this word, you'll need to log in. Log In prod·​uct | \ ˈprä-(ˌ)dəkt \ Definition of product 1: the number or expression resulting from the multiplication together of two or more numbers or expressions 2a(1): something produced especially : COMMODITY sense 1 (2): something (such as a service) that is marketed or sold as a commodity b: something resulting from or necessarily following from a set of conditions a product of his environment 3: the amount, quantity, or total produced 4: CONJUNCTION sense 5 </textarea> <br/> <hr/> <div id="preview"> </div>

over 3 years ago · Juan Pablo Isaza Report

0

Aquí hay un ejemplo muy básico:

 const preview = document.querySelector("#preview"); function getSelectionText() { var text = ""; if (window.getSelection) { text = window.getSelection().toString(); } else if (document.selection && document.selection.type != "Control") { text = document.selection.createRange().text; } return text; } document.addEventListener("click", () => { const selectedText = getSelectionText(); if (selectedText !== "") { preview.innerHTML = preview.innerHTML.replaceAll( selectedText, `<mark>${selectedText}</mark>` ); } }); function showPreview() { let value = document.querySelector("textarea").value.trim(); value = value.replace("<", "&lt;"); value = value.replace(">", "&gt;"); preview.innerHTML = value; }
 ::-moz-selection { /* Code for Firefox */ color: red; background: yellow; } ::selection { color: red; background: yellow; } #preview { width: 410px; border: solid 1px #999; padding: 5px; }
 <textarea rows="10" cols="50" onInput="showPreview();">Lorem ipsum dolor, sit amet consectetur adipisicing elit.</textarea> <br /> <hr /> <div id="preview"></div>

over 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

Show me some job opportunities
There's an error!