Ver Mensaje Individual
  #1 (permalink)  
Antiguo 19/10/2011, 09:52
Eux
 
Fecha de Ingreso: octubre-2010
Mensajes: 60
Antigüedad: 14 años, 1 mes
Puntos: 0
Imposible resaltar texto en iframe NO EDITABLE

Hola a tod@s,

Me gustaría hacer una página en la cual tengo un texto NO EDITABLE y que el usuario pueda resaltar en amarillo algunas partes del texto.

Al principio lo quise hacer con un DIV pero tuve el mismo problema que tengo ahora mismo con iframe, y es que no soy capaz de poner el texto NO EDITABLE dado que eso hace que entonces no se pueda resaltar en amarillo.

Una de las soluciones que pensé que funcionaría seguro era hacerle lo siguiente a la funcion colorFondo:


function colorFondo(c){
editor.designMode='on';
var h = window.ActiveXObject?'backcolor':'hilitecolor';
editor.execCommand(h,false,c);
editor.designMode='off';
}

pues mi gozo en un pozo ya que esa solución sólo me valió para OPERA

Aquí os dejo el código entero por si alguien podría echarme una mano y hacer alguna prueba, o quizás le sirva para algún proyecto.

Código Javascript:
Ver original
  1. <script>
  2.  
  3. var editor;
  4.  
  5. function $(id){
  6.     return document.getElementById(id);
  7. }
  8.  
  9. function colorFondo(c){
  10.     var h = window.ActiveXObject?'backcolor':'hilitecolor';
  11.     editor.execCommand(h,false,c);
  12. }
  13.  
  14.  
  15. window.onload=function(){    
  16.     editor=$('edit').contentDocument || $('edit').contentWindow.document;    
  17.     editor.designMode='on';
  18. }
  19.  
  20. function formato(f){   
  21.     editor.execCommand(f, false, null);
  22. }
  23.  
  24. </script>  
  25. </head>
  26.  
  27. <body>
  28.  
  29.  
  30.  
  31. <form id="form1" name="form1" method="post" action="">
  32.  
  33.   <iframe src="texto.html" id="edit" width="100%" height="300" style=" border:1px solid #000;" ></iframe>
  34.  
  35.   <input type="button" name="Submit1" value="Resaltar" onclick="colorFondo('yellow');" />
  36.   <input type="button" name="Submit2" value="Deshacer" onclick="formato('undo')" />
  37.   <input type="button" name="Submit3" value="Rehacer" onclick="formato('redo')" />
  38.  
  39. </form>
  40.  
  41. <br /><br />
  42.  
  43. <input type="button" value="Ver HTML" onclick="alert(editor.body.innerHTML)">
  44.  
  45.  
  46. </body>
  47. </html>

Gracias de antemano.