nl2br() équivalent en javascript [dupliquer]

possibilité de duplication:

jQuery convertir les sauts de ligne en br (équivalent nl2br)

actuellement, j'ajoute <BR> pour chaque evt.which == 13 . Y a - t-il un nl2br() pour JavaScript, donc je peux supprimer ce evt.which == 13 ?

en quoi est-ce différent de php.js

$('#TextArea').keypress(function(evt) {

    if (evt.which == 13) {

        var range           = $('#TextArea').getSelection();
        var image_selection = range.text;

        $('#TextArea').replaceSelection('<BR>');
        $('#TextArea1').html($('#TextArea').val());
    }
});
52
demandé sur Community 2011-09-19 11:50:12

2 réponses

regardez nl2br sur php.js , ce qui semble exactement ce que vous cherchez. En gros, c'est:

function nl2br (str, is_xhtml) {
    if (typeof str === 'undefined' || str === null) {
        return '';
    }
    var breakTag = (is_xhtml || typeof is_xhtml === 'undefined') ? '<br />' : '<br>';
    return (str + '').replace(/([^>\r\n]?)(\r\n|\n\r|\r|\n)/g, '' + breakTag + '');
}

EDIT:

votre exemple utilisant nl2br() peut être modifié comme ceci:

$('#TextArea').keypress(function(evt){
        $('#TextArea1').html(nl2br($('#TextArea').val()));
    });

(notez que cela met à jour #TextArea1 sur chaque porte-clés et ne change pas la valeur de #TextArea qui est ce que je pense que vous cherchez, mais je pourrais être malentendu)

Edit 2:

Si vous voulez obtenir le comportement de votre ancienne fonction (en insérant <br/> à #TextArea ) faites ceci:

$('#TextArea').keypress(function(evt){
        $('#TextArea').html(nl2br($('#TextArea').val())); // replace linebreaks first
        $('#TextArea1').html($('#TextArea').val()); // copy to #TextArea1
    });
78
répondu oezi 2018-02-18 10:03:07

Voici une fonction nl2br en php.js.

function nl2br (str, is_xhtml) {
  // http://kevin.vanzonneveld.net
  // +   original by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  // +   improved by: Philip Peterson
  // +   improved by: Onno Marsman
  // +   improved by: Atli Þór
  // +   bugfixed by: Onno Marsman
  // +      input by: Brett Zamir (http://brett-zamir.me)
  // +   bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  // +   improved by: Brett Zamir (http://brett-zamir.me)
  // +   improved by: Maximusya
  // *     example 1: nl2br('Kevin\nvan\nZonneveld');
  // *     returns 1: 'Kevin<br />\nvan<br />\nZonneveld'
  // *     example 2: nl2br("\nOne\nTwo\n\nThree\n", false);
  // *     returns 2: '<br>\nOne<br>\nTwo<br>\n<br>\nThree<br>\n'
  // *     example 3: nl2br("\nOne\nTwo\n\nThree\n", true);
  // *     returns 3: '<br />\nOne<br />\nTwo<br />\n<br />\nThree<br />\n'
  var breakTag = (is_xhtml || typeof is_xhtml === 'undefined') ? '<br ' + '/>' : '<br>'; // Adjust comment to avoid issue on phpjs.org display

  return (str + '').replace(/([^>\r\n]?)(\r\n|\n\r|\r|\n)/g, '' + breakTag + '');
}
15
répondu xdazz 2013-05-01 13:15:53