2012-08-15 22 views

Respuesta

9

puede probar el proyecto google-diff-match-patch, este proyecto ofrece algoritmos robustos para realizar las operaciones necesarias para sincronizar texto sin formato.

Demostración: http://jsfiddle.net/N6bAn/

Código:

<div class="test"> 
    <div id="oldStr" class="text">the stackoverflow question and answer version control is very well,i want to do this use javascript,but i don't know how to start,who can give some suggestion?thanks</div> 
    <div id="newStr" class="text">Stack Overflow's diff view is very good. I want to do this using javascript,but i don't know how to start,who can give some suggestion?thanks</div> 
</div> 
<input type="button" value="GO" onclick="launch()" /> 
<div class="test"> 
    <div class="text" id="outputOldStr"></div> 
    <div class="text" id="outputNewStr"></div> 
</div> 
<script type="text/javascript"> 
    var dmp = new diff_match_patch(); 

    function launch() { 
     var text1 = document.getElementById('oldStr').innerHTML; 
     var text2 = document.getElementById('newStr').innerHTML; 
     dmp.Diff_EditCost = 8; 

     var d = dmp.diff_main(text1, text2); 
     dmp.diff_cleanupEfficiency(d); 
     var oldStr = "", newStr = ""; 
     for (var i = 0, j = d.length; i < j; i++) { 
      var arr=d[i]; 
      if (arr[0] == 0) { 
       oldStr += arr[1]; 
       newStr += arr[1]; 
      } else if (arr[0] == -1) { 
       oldStr += "<span class='text-del'>" + arr[1] + "</span>"; 
      } else { 
       newStr += "<span class='text-add'>" + arr[1] + "</span>"; 
      } 
     } 
     document.getElementById('outputOldStr').innerHTML = oldStr; 
     document.getElementById('outputNewStr').innerHTML = newStr; 
    } 
</script> 
+0

sí, esto sólo me parece – artwl

+1

Fui a través de este y terminó creando una biblioteca para ayudar con el "trabajo de presentación" necesaria para usar 'diff_match_patch ': https://github.com/arnab/jQuery.PrettyTextDiff – arnab

+0

Contenedor angular para' google-diff-match-patch': https://github.com/amweiss/angular-diff-match-patch – fiat

3

Hay bibliotecas de JavaScript que hace la visualización diff. Estos son unos pocos ejemplos que encontré:

no he probado ninguno de ellos, por lo que lamentablemente no se puede decir que es el más adecuado para sus necesidades, pero podría valer la pena echarles un vistazo.

actualización

jsdifflib parece prometedor, hay disponibles a demo que se podía tratar.

Cuestiones relacionadas