Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 4102568
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 20, 20262026-05-20T20:50:39+00:00 2026-05-20T20:50:39+00:00

In jQuery, I want to add a class to all visible elements that are

  • 0

In jQuery, I want to add a class to all visible elements that are the 5th child or greater, and another class to each element that isn’t a 4th child. Previously, I was doing this:

$overlay.find('> .container .content .selector').not(':nth-child(4n)').addClass('hasRightMargin');
$overlay.find('> .container .content .selector:nth-child(n+5)').addClass('hasTopMargin');

However, now I’m toggling the visibility of the first .selector, and :nth-child does not take visibility into account, so this does not work as I want, because it’s still counting the invisible element:

$overlay.find('> .container .content .selector:visible').not(':nth-child(4n)').addClass('hasRightMargin');
$overlay.find('> .container .content .selector:visible:nth-child(n+5)').addClass('hasTopMargin');

Is there a way to do what I want in one selector? Or will I have to loop through all .selector elements using each and filter them there manually?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-20T20:50:40+00:00Added an answer on May 20, 2026 at 8:50 pm

    I think this should do the trick.

    $overlay.find('> .container .content .selector:visible:not(:odd:odd)').addClass('hasRightMargin');
    $overlay.find('> .container .content .selector:visible:gt(3)').addClass('hasTopMargin');
    

    Your primary issue is that nth child selects all elements that are the nth child of their parent, not the nth elements in the set. Also, keep in mind that selectors such as :odd,:even,:gt,:lt are 0-indexed. So :odd selects the elements 1,3,5,etc. which are the 2nd,4th,6th elements on the page. And :odd:odd selects every 4th element on the page. Likewise, :gt(3) selects all elements with index of 4 or more, which is the 5th element and beyond.

    See here for a jsfiddle that, I think, demonstrates what you were looking for. Note the hidden divs that get passed over.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I want to show first element that is hidden by jquery. my html code
I am trying to write a jQuery script that will add a class to
I'm using jQuery and I want to check the existence of an element in
I have some jQuery/JavaScript code that I want to run only when there is
The setting is easy; I want to be able to add a class to
How can I toggleClass and remove class from all other elements? Consider a div
How to add pause button in this jQuery image slider? I want to add
I want to use jQuery with a GridView which contains textboxes, but I'm stuck
I want to use jquery-ui widgets and so I am including jquery.ui.js. Would I
I want to split up the jQuery .js file into two, but I have

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.