admin管理员组文章数量:1345468
I was just wondering if there is a way to select the last WORD in a DIV. I don't think there is any obvious way to do this, so are there any work arounds?
I don't mind using CSS or Javascript to achieve this.
Thanks in advance
I was just wondering if there is a way to select the last WORD in a DIV. I don't think there is any obvious way to do this, so are there any work arounds?
I don't mind using CSS or Javascript to achieve this.
Thanks in advance
Share Improve this question edited Aug 16, 2011 at 8:29 Reporter 3,9485 gold badges35 silver badges49 bronze badges asked Aug 16, 2011 at 8:21 Lee PriceLee Price 5,21211 gold badges35 silver badges36 bronze badges6 Answers
Reset to default 3<div>
or no <div>
, it boils down to basic String manipulation (using the match()
) method.
var words = $('#your_div').text().match(/(\w+)/g);
if (words.length) {
var last_word = words[words.length - 1];
}
We build an array of all words using the match()
method, and then get the last one (var last_word = words[words.length - 1];
), but only if some words were found (if (words.length)
).
Try this:
var $div = $('div');
$div.html($div.text().replace(/(\w+?)$/, '<span>$1</span>'));
Here is a demo
If the text inside the div does not contain any div element, then this will work. Otherwise, it won't, because it will replace all the previous elements with plain text.
If you are after another regular expression based solution, you could try (uses jQuery):
$(function() {
$('div').each(function() {
var $div = $(this);
var text = $div.text(); // get the text of everything inside the div
// the next line gets the last word followed only by non-word characters in that text
// NB: the [\s\S] trick is to match any character, *including* new lines
var last_word = $.trim(text).replace(/^[\s\S]*\b(\w+)\b[\W]*$/i, '$1');
// this is from a jsFiddle I tried to post to test it.
$('#output').append($div.attr('id') + ': Last word = ' + last_word + '<br />');
});
});
This works.
var text = 'Lorem Ipsum Dolor Sit Amet';
var textSplit = text.split(' ');//split the text with space characters
var lastPart = textSplit.pop(); // retrieve the last word from the string
var firstPart = textSplit.join(' '); // retriece the words except the last word
var result = firstPart + ' <strong>' + lastPart + '</strong>'; //join first part and last part and put the required html for the last word
You could probably use Javascript and HTML DOM to access the content of the div and then simply split the string (with a space as separator) and take the last split part.
Here's my solution to this question:
Demo: http://wecodesign./demos/stackoverflow-7075397.htm
function getLastWord( words ) {
lastWord = words.split( ' ' ).pop();
return lastWord;
}
$( document ).ready( function() {
theWords = $( '#theWords' ).html();
lastWord = getLastWord( theWords );
$( '#lastWord' ).html( lastWord );
} );
SCOPE CREEP! Given the new requirements to dynamically inject the span tag, I've modified the code as follows (I've also updated my demo):
$( document ).ready( function() {
theWords = $( '#theWords' ).html();
lastWord = getLastWord( theWords );
appendCon = '#lastWord';
$( appendCon) .append( $( '<span> '+lastWord+'</span>' ) );
} );
本文标签: javascriptSelect last word in a containerStack Overflow
版权声明:本文标题:javascript - Select last word in a container - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743768300a2535650.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论