I have recently done a very simple highlighting with jQuery and a highlight plugin. It looks like this:
$('myButton').click(function() {
$('body').highlight($('#myInputText').val());
});
But I wonder how can I do the Chrome like highlighting, I mean highlight the letters whenever I type in some letter in textbox without submitting. I think maybe use a keyup event... Any ideas?
Thanks Andy, i changed 'this[0]' to 'search[i]' in your code and it works if there is only one 'p' tag
$(document).ready(function(){
  var search = ['p', 'div', 'span'];
  $("#highlighter").bind('keyup', function(e){
    var pattern = $(this).val();
    $.each(search, function(i){
        var str = search[i];        
        var orgText = $(str).text();
        orgText = orgText.replace(pattern, function($1){
          return "<span style='background-color: red;'>" + $1 + "</span>"
        });
        $(str).html(orgText);
    });    
  });
});
js code to highlight the text. There are many built-in functions in mark. js but we are using two functions for our requirement that is mark() and unmark() function respectively. Here mark() is used to highlight the search text and unmark() is used to remove highlighting the text that is highlighted before.
Simply navigate to a web page, then, open toolbar popup UI and type your keyword in the designated area. Then click on the "Find" button or press "Enter" on your keyboard. All the matching words within the web page will be highlighted with yellow color.
I made quick excersise out of it, code:
    $(document).ready(function(){
    var search = ['p', 'div', 'span'];
    $("#highlighter").bind('keyup', function(e){
    var pattern = $(this).val();
    $.each(search, function(i){
        var str = this[0];        
        var orgText = $(str).text();
        orgText = orgText.replace(pattern, function($1){
          return "<span style='background-color: red;'>" + $1 + "</span>"
        });
        $(str).html(orgText);
    });    
  });
});
link: http://jsbin.com/amica3/edit
$('#myInputText').keypress(function(e) {
    switch (e.keyCode) {
        case 13: // "Enter" was pressed; handle it if you want
            return false;
        case 27: // ESC was pressed; handle it if you want
            return false;
    }
    $('body').highlight($(this).val());
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With