Remove ' ' - still trying

守給你的承諾、 提交于 2019-12-03 08:26:16

问题


Still looking for a way to delete ' ' from my html code, found number of ways on stackoverlow.com, but neither of those seam to work!

HTML

<p>No Space</p>
<p>&nbsp;1 Space</p>
<p>&nbsp;&nbsp;2 Spaces</p>
<p>&nbsp;&nbsp;&nbsp;3 Spaces</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;4 Spaces</p>

jQuery

$(document).ready(function() {

    $('p').text().replace(/ /g, '');
    //$('p').html($(this).html().replace(/&nbsp;/gi,''));

});

jsfiddle - playground http://jsfiddle.net/MrTest/hbvjQ/85/

Any help much appreciated.
Pete


回答1:


You have &nbsp in your code instead of &nbsp;

$('p').each(function(){
    $(this).html($(this).html().replace(/&nbsp;/gi,''));
});

http://jsfiddle.net/genesis/hbvjQ/76/




回答2:


This one will replace every white-space character:

$('p').text(function (i, old) {
    return old.replace(/\s/g, '')
});

Or if you only want to replace non-breaking spaces:

$('p').text(function (i, old) {
    return old.replace(/\u00A0/g, '')
});

jsFiddle Demo

I am setting the new value using a closure as a parameter for .text().


Please note that HTML entities need a closing ; in the end.




回答3:


Here's a non-jQuery answer, since using jQuery for such a task is overkill unless you're already using it for something else on your site:

var p = document.getElementsByTagName('p');

Array.prototype.forEach.call(p, function(el) {
  el.innerHTML = el.innerHTML.replace(/&nbsp;/gi, '');
});
<p>No Space</p>
<p>&nbsp;1 Space</p>
<p>&nbsp;&nbsp;2 Spaces</p>
<p>&nbsp;&nbsp;&nbsp;3 Spaces</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;4 Spaces</p>



回答4:


try

$('p').each(function() {
     $(this).html($(this).html().replace(/ /g, ''));
});

or if you wish to delete the &nbsp try

$('p').each(function() {
      $(this).html($(this).html().replace('&nbsp;', ''));
});

also please note that space is &nbsp; and not &nbsp (you are missing ;)




回答5:


Based on bažmegakapa' answer, this can be used on elements containing other elements.

$('p').html(function (i, old) {
    return old.replace(/&nbsp;/g, '')
});

.text() gets rid of html elements; .html() does not




回答6:


Here is the code:

$('p').each( function() {
    var elem = $( this );
    elem.html( elem.html().replace( /&nbsp;/g,'' ) );
} );

And here is jsfiddle: http://jsfiddle.net/hbvjQ/62/



来源:https://stackoverflow.com/questions/6452731/remove-nbsp-still-trying

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!