Remove ' ' - still trying

只谈情不闲聊 提交于 2019-12-02 22:08:54
genesis

You have &nbsp in your code instead of  

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

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

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.

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(/ /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>

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 ;)

fregante

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

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/

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