2011-10-15 18 views
12

¿Alguien podría tener alguna idea de cómo hacer una búsqueda y reemplazo cuando puede simplemente hacer clic en siguiente y acceder al siguiente elemento encontrado?Busque y reemplace por un Textarea

Editar:

Para una caja de texto. Quiero un código Javascript que pueda agregar Buscar y Reemplazar a Textarea. No quiero solo usar.

búsqueda()

o Reemplazar().

Al Momento im tratando esto:

function allIndexes() { 
var indices = new Array(); 
var index = 0; 
var i = 0; 
while(index = $('#text').val().indexOf($('#search').val(), index) > 0) { 
indices[i] = index; 
i++; 
} 
return indices; 
} 

Pero eso no funciona en absoluto.

Respuesta

9

Actualicé mi respuesta anterior y terminé la funcionalidad de búsqueda y reemplazo según la dirección en la que se describía mi publicación anterior. Probé esto en Chrome 14, IE8 y Firefox 3.6.

Buscar: seleccionará la siguiente instancia del término de búsqueda.

Buscar/Reemplazar: sustituirá a la siguiente aparición de la cadena de búsqueda y seleccione la sustitución

Reemplazar todo: reemplazará todas las apariciones y seleccione la parte del texto que ha sido sustituido última

Espero que esto sea ahora, lo que estabas buscando. Definitivamente usted debería ser capaz de ir desde aquí y el estilo de este o hacer una clase adecuada de este ...

<script src="jquery.js" type="text/javascript"></script>  

<textarea id="txtArea" style="width: 300px; height:100px"> 
    This is a test. A test, i say. The word TEST is mentioned three times. 
</textarea> 

<p> 
    <label for="termSearch">Search</label> 
    <input type="text" id="termSearch" name="termSearch" value="test" /><br/> 
    <label for="termReplace">Replace</label> 
    <input type="text" id="termReplace" name="termReplace" value="solution" /><br/> 
    <label for="caseSensitive">Case Sensitive</label> 
    <input type="checkbox" name="caseSensitive" id="caseSensitive" /><br/> 
    <a href="#" onclick="SAR.find(); return false;" id="find">FIND</a><br/> 
    <a href="#" onclick="SAR.findAndReplace(); return false;" id="findAndReplace">FIND/REPLACE</a><br/> 
    <a href="#" onclick="SAR.replaceAll(); return false;" id="replaceAll">REPLACE ALL</a><br/> 
</p> 

<script type="text/javascript"> 
    var SAR = {}; 

    SAR.find = function(){ 
     // collect variables 
     var txt = $("#txtArea").val(); 
     var strSearchTerm = $("#termSearch").val(); 
     var isCaseSensitive = ($("#caseSensitive").attr('checked') == 'checked') ? true : false; 

     // make text lowercase if search is supposed to be case insensitive 
     if(isCaseSensitive == false){ 
      txt = txt.toLowerCase(); 
      strSearchTerm = strSearchTerm.toLowerCase(); 
     } 

     // find next index of searchterm, starting from current cursor position 
     var cursorPos = ($("#txtArea").getCursorPosEnd()); 
     var termPos = txt.indexOf(strSearchTerm, cursorPos); 

     // if found, select it 
     if(termPos != -1){ 
      $("#txtArea").selectRange(termPos, termPos+strSearchTerm.length); 
     }else{ 
      // not found from cursor pos, so start from beginning 
      termPos = txt.indexOf(strSearchTerm); 
      if(termPos != -1){ 
       $("#txtArea").selectRange(termPos, termPos+strSearchTerm.length); 
      }else{ 
       alert("not found"); 
      } 
     } 
    }; 

    SAR.findAndReplace = function(){ 
     // collect variables 
     var origTxt = $("#txtArea").val(); // needed for text replacement 
     var txt = $("#txtArea").val(); // duplicate needed for case insensitive search 
     var strSearchTerm = $("#termSearch").val(); 
     var strReplaceWith = $("#termReplace").val(); 
     var isCaseSensitive = ($("#caseSensitive").attr('checked') == 'checked') ? true : false; 
     var termPos; 

     // make text lowercase if search is supposed to be case insensitive 
     if(isCaseSensitive == false){ 
      txt = txt.toLowerCase(); 
      strSearchTerm = strSearchTerm.toLowerCase(); 
     } 

     // find next index of searchterm, starting from current cursor position 
     var cursorPos = ($("#txtArea").getCursorPosEnd()); 
     var termPos = txt.indexOf(strSearchTerm, cursorPos); 
     var newText = ''; 

     // if found, replace it, then select it 
     if(termPos != -1){ 
      newText = origTxt.substring(0, termPos) + strReplaceWith + origTxt.substring(termPos+strSearchTerm.length, origTxt.length) 
      $("#txtArea").val(newText); 
      $("#txtArea").selectRange(termPos, termPos+strReplaceWith.length); 
     }else{ 
      // not found from cursor pos, so start from beginning 
      termPos = txt.indexOf(strSearchTerm); 
      if(termPos != -1){ 
       newText = origTxt.substring(0, termPos) + strReplaceWith + origTxt.substring(termPos+strSearchTerm.length, origTxt.length) 
       $("#txtArea").val(newText); 
       $("#txtArea").selectRange(termPos, termPos+strReplaceWith.length); 
      }else{ 
       alert("not found"); 
      } 
     } 
    }; 

    SAR.replaceAll = function(){ 
     // collect variables 
     var origTxt = $("#txtArea").val(); // needed for text replacement 
     var txt = $("#txtArea").val(); // duplicate needed for case insensitive search 
     var strSearchTerm = $("#termSearch").val(); 
     var strReplaceWith = $("#termReplace").val(); 
     var isCaseSensitive = ($("#caseSensitive").attr('checked') == 'checked') ? true : false; 

     // make text lowercase if search is supposed to be case insensitive 
     if(isCaseSensitive == false){ 
      txt = txt.toLowerCase(); 
      strSearchTerm = strSearchTerm.toLowerCase(); 
     } 

     // find all occurances of search string 
     var matches = []; 
     var pos = txt.indexOf(strSearchTerm); 
     while(pos > -1) { 
      matches.push(pos); 
      pos = txt.indexOf(strSearchTerm, pos+1); 
     } 

     for (var match in matches){ 
      SAR.findAndReplace(); 
     } 
    }; 


    /* TWO UTILITY FUNCTIONS YOU WILL NEED */ 
    $.fn.selectRange = function(start, end) { 
     return this.each(function() { 
      if(this.setSelectionRange) { 
       this.focus(); 
       this.setSelectionRange(start, end); 
      } else if(this.createTextRange) { 
       var range = this.createTextRange(); 
       range.collapse(true); 
       range.moveEnd('character', end); 
       range.moveStart('character', start); 
       range.select(); 
      } 
     }); 
    }; 

    $.fn.getCursorPosEnd = function() { 
     var pos = 0; 
     var input = this.get(0); 
     // IE Support 
     if (document.selection) { 
      input.focus(); 
      var sel = document.selection.createRange(); 
      pos = sel.text.length; 
     } 
     // Firefox support 
     else if (input.selectionStart || input.selectionStart == '0') 
      pos = input.selectionEnd; 
     return pos; 
    }; 
</script> 
+0

¿No hay un cuadro de búsqueda para esto? No entiendo esto. – Shawn31313

+0

Además, esto no es lo que estaba buscando, pero es para probarlo. :) Obtienes la mejor respuesta debido a tu excelente código. Y te puedes permitir hacerlo. – Shawn31313

+0

Actualicé mi anterior dirección aproximada y ahora es un ejemplo completamente funcional de funcionalidad de búsqueda y reemplazo en un área de texto a través de JavaScript. Avísame si esto es más útil. –

0

Javascript ------------------- --------------

 function dog(id) 
     { 
      return document.getElementById(id); 
     } 
     function find() 
     { 
      var a=dog("txtf").value; 
      var b=dog("ta").value; 
      var c=""; 
      for(var i=0;i<b.length;i++) 
      { 
       var d=b.substr(i,a.length) 
       if (d.indexOf(a) > -1)   
        c=c +" " + (d.indexOf(a)+i); 
      } 
      if (c!="") 
      { 
       alert(c); 
      } 
      else 
      { 
       alert("not find"); 
      } 
     } 
     function replace() 
     { 
      var a=dog("txtf").value; 
      var b=dog("ta").value; 
      var c=""; 
      for(var i=0;i<b.length;i++) 
      { 
       var d=b.substr(i,a.length) 
       if (d.indexOf(a) > -1)  
       { 
        c=c + dog("txtr").value; 
        i=i+a.length-1; 
       } 
       else 
        c=c + b.charAt(i); 
      } 
      dog("ta").value=c; 
     } 

html ---------------------------- --------------------

<input type="text" id="txtf" value="this" style="width:427px"/> 
    <input type="button" value="Find" style="width:70px" onclick="find()" /> </br> 
    <input type="text" id="txtr" value="it" style="width:427px"/> 

    <input type="button" value="Replace" style="width:70px" onclick="replace()"/> </br> 
    <textarea id="ta" style="width:500px;height:500px"> 

esta es un área de texto para la prueba de encontrar & reemplazar las funciones este es un proyecto para encontrar & reemplazar en el lenguaje de programación html

0

// hay un error en el desplazamiento, por lo que a continuación está la corrección funcionando bien en cromo.

//Complete code 

var SAR = {};

  SAR.find = function() { 
       debugger; 
       var parola_cercata = $("#text_box_1").val(); // the searched word 
       // make text lowercase if search is supposed to be case insensitive 
       var txt = $('#remarks').val().toLowerCase(); 
       parola_cercata = parola_cercata.toLowerCase(); 

       var posi = jQuery('#remarks').getCursorPosEnd(); // take the position of the word in the text 

       var termPos = txt.indexOf(parola_cercata, posi); 

       if (termPos !== -1) { 
        debugger; 
        var target = document.getElementById("remarks"); 
        var parola_cercata2 = $("#text_box_1").val(); 
        // select the textarea and the word 
        if (target.setSelectionRange) { 

         if ('selectionStart' in target) { 
          target.selectionStart = termPos; 
          target.selectionEnd = termPos; 
          this.selectionStart = this.selectionEnd = target.value.indexOf(parola_cercata2); 
          target.blur(); 
          target.focus(); 
          target.setSelectionRange(termPos, termPos + parola_cercata.length); 
         } 
        } else { 
         var r = target.createTextRange(); 
         r.collapse(true); 
         r.moveEnd('character', termPos + parola_cercata); 
         r.moveStart('character', termPos); 
         r.select(); 
        } 
       } else { 
        // not found from cursor pos, so start from beginning 
        termPos = txt.indexOf(parola_cercata); 
        if (termPos !== -1) { 
         var target = document.getElementById("remarks"); 
         var parola_cercata2 = $("#text_box_1").val(); 
         // select the textarea and the word 
         if (target.setSelectionRange) { 

          if ('selectionStart' in target) { 
           target.selectionStart = termPos; 
           target.selectionEnd = termPos; 
           this.selectionStart = this.selectionEnd = target.value.indexOf(parola_cercata2); 
           target.blur(); 
           target.focus(); 
           target.setSelectionRange(termPos, termPos + parola_cercata.length); 
          } 
         } else { 
          var r = target.createTextRange(); 
          r.collapse(true); 
          r.moveEnd('character', termPos + parola_cercata); 
          r.moveStart('character', termPos); 
          r.select(); 
         } 
        } else { 
         alert("not found"); 
        } 
       } 
      }; 


      $.fn.getCursorPosEnd = function() { 
       var pos = 0; 
       var input = this.get(0); 
       // IE Support 
       if (document.selection) { 
        input.focus(); 
        var sel = document.selection.createRange(); 
        pos = sel.text.length; 
       } 
       // Firefox support 
       else if (input.selectionStart || input.selectionStart === '0') 
        pos = input.selectionEnd; 
       return pos; 
      }; 
     </script>