Enhancing Sitecore Search Results: Highlighting Searched Terms

Enhancing Sitecore Search Results: Highlighting Searched Terms

Optimize Sitecore Search Results by Highlighting Keywords

·

7 min read

Sitecore Search's robust functionality helps users find relevant content quickly. However, when users search on your website, it's important to provide a seamless and user-friendly experience. One way to improve search results is by dynamically highlighting the searched terms within the content snippets. In this article, we’ll explore how to do this using Sitecore Search's built-in features and the Sitecore Search SDK.

Why Highlight Searched Terms?

  1. Improved Readability: Highlighting searched terms helps users quickly spot relevant content in the search results.

  2. User Engagement: Highlighting searched terms gives clear visual cues that encourage users to explore more, boosting engagement and lowering bounce rates.

  3. Accessibility: Highlighting helps users with visual impairments or cognitive challenges easily find relevant content. 🔝

Implementation Steps

1. Configure Your Source

Before implementing term highlighting, ensure you have configured a source in the Sitecore Search Customer Engagement Console (CEC). In the source, you define the settings that help you extract and index content from your website.

You can find more details on how to configure a source in this video:

2. Configure Highlighting Settings

In the Sitecore Search Customer Engagement Console (CEC), you set up where the content from your website will be stored. These storage locations are called attributes or metadata, and they are part of an entity in Sitecore Search. The default entity type is Content, which can store content from different page types on your website, but you can also create custom entities if needed. 🔝

Once you have defined the attributes, create a list of attributes you want to highlight when a searched keyword is found in those attributes (or fields). To do this, log in to Sitecore Search CEC>Administration>Domain Settings>Textual Relevance and configure the attribute for textual relevance.

Textual relevance tells Sitecore Search which parts of your indexed document to search for the matching keyword. 🔝

If the image above is not visible, you can check it here.

In the settings above, you have seen the analyzer setting, which is used by Sitecore Search to apply the relevant algorithm or logic while searching for the keyword in the indexed document attributes (which you defined as textual relevance). The default analyzer added by Sitecore Search is the Multi-Locale Standard Analyzer. You can find more details about Sitecore Search Analyzer here.

3. Customize Your Search Results Rendering

When working with the Sitecore Search SDK, search results are usually displayed using a specific rendering or view. Customize these renderings to include the highlighted terms.

In this article, I will be using the Sitecore-provided Sitecore Developer Portal GitHub repository and the name and description attributes from the Content entity. 🔝

To highlight text using the Search API, we need to use the Highlight helper and set the necessary attributes:

  • Update the object that holds the search results to include the highlighted attributes.

  • Update the fields property in the setSearchQueryHighlight method to include the highlighted attributes.

  • Update the pre_tag and post_tag properties in the setSearchQueryHighlight method to include the HTML tags that wrap the searched keyword.

  • Update the logic to show or hide the highlighted text.

Preview Search Experience

The Preview Search experience is displayed by the Preview Search Widget, and I have used the color GREEN to highlight the text. 🔝

The change log for Preview Search Rendering includes the following changes:

You can find more details about the Preview Search Widget changes here.

🚀 Output

🔎 Query: used by the Preview Search Widget to highlight the keyword being searched using the name and description fields

{
  "context": {
    "page": {
      "uri": "/"
    },
    "user": {
      "uuid": "xxxxxx"
    },
    "locale": {
      "country": "us",
      "language": "en"
    }
  },
  "widget": {
    "items": [
      {
        "rfk_id": "rfkid_6", // For Preview Search Widget
        "search": {
          "content": {},
          "suggestion": [
            {
              "name": "name_suggester",
              "max": 10
            }
          ],
          "limit": 6,
          "query": {
            "highlight": {  // highlight fields
              "fields": [
                "name",
                "description"
              ],
              "fragment_size": 100,
              "pre_tag": "<strong style=\"color:green\">",
              "post_tag": "</strong>"
            },
            "keyphrase": "docker" // Searched Keyword
          }
        },
        "entity": "content"
      }
    ]
  }
}

Search Results Experience

The Search Results experience is displayed by the Search Results Widget, and I have used the color RED to highlight the text. 🔝

The change log for Search Results Rendering includes the following changes:

You can find more details about the Search Results Widget changes here.

🚀 Output

🔎 Query: used by the Search Results Widget to highlight the keyword being searched using the name and description fields

{
  "context": {
    "page": {
      "uri": "/search"
    },
    "user": {
      "uuid": "xxxxxx"
    },
    "locale": {
      "country": "us",
      "language": "en"
    }
  },
  "widget": {
    "items": [
      {
        "rfk_id": "rfkid_7", // Search Results Widget
        "search": {
          "content": {},
          "facet": {
            "all": true
          },
          "offset": 0,
          "sort": {
            "choices": true,
            "value": [
              {
                "name": "page_lastmodifieddate" // Sort Field
              }
            ]
          },
          "limit": 24,
          "query": {
            "keyphrase": "docker", // Searched Keyword
            "highlight": {  // highlight fields
              "fields": [
                "name",
                "description"
              ],
              "fragment_size": 100,
              "pre_tag": "<strong style=\"color:red\">",
              "post_tag": "</strong>"
            }
          }
        },
        "entity": "content"
      }
    ]
  }
}

💡Conclusion

Highlighting searched terms in Sitecore search results enhances user experience and search functionality. By following these steps, you can easily implement search term highlighting in your front-end application. Remember to test and refine your implementation for optimal results. Happy searching! 🔎

You can find more details on how to effectively use the Sitecore Search experience in the article Discover Sitecore Search: Key Features and Components with Sitecore Developer Portal GitHub Repo🔝

🙏Credit/References

🏓Pingback

Integrating a preview search widgetConfiguring search experiencesSitecore Search series
Getting to know Sitecore SearchFull-page search widget eventsSetting up Source in Sitecore Search
How To Setup A Sitecore Search SourceConfiguring locale extractorsCoveo for Sitecore - Boost Sitecore Conversions
Sitecore search advanced web crawler with js extractor examplesitecore search api crawlerA Day with Sitecore Search
The basic preview search widget templateHow To Setup A Sitecore Search Source And Prep For Using The Sitecore Search Starter Kitsitecore search advance web crawler
sitecore search enginesitecore search indexsitecore search api 🔝
sitecore search facetsgoogle site crawler testindex sitecore_master_index was not found
sitecore-jssmonster crawler search enginesitecore search widget
sitecore searchstaxwhat is a search widgethow to search a website without a search bar
Sitecore javascript servicesSitecore javascript renderingsitecore search facets
sitecore jss githubsitecore search apisitecore search engine
Sitecore graphql queriessitecore elastic searchfind sitecore version
how does sitecore search workwhat is indexing in Sitecore Search?sitecore search by field value
Sitecore Search API CrawlerImprove Sitecore Searchsitecore wildcard item
search widget experience buildersitecore icon findersitecore widgets 🔝
sitecore searchresultitemsitecore query cheat sheetsitecore jss dictionary
jss sitecore githubsitecore search githubSitecore/Sitecore-Search-JS-SDK-Starter-Kit