Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      CodeSOD: A Unique Way to Primary Key

      July 22, 2025

      BrowserStack launches Figma plugin for detecting accessibility issues in design phase

      July 22, 2025

      Parasoft brings agentic AI to service virtualization in latest release

      July 22, 2025

      Node.js vs. Python for Backend: 7 Reasons C-Level Leaders Choose Node.js Talent

      July 21, 2025

      The best CRM software with email marketing in 2025: Expert tested and reviewed

      July 22, 2025

      This multi-port car charger can power 4 gadgets at once – and it’s surprisingly cheap

      July 22, 2025

      I’m a wearables editor and here are the 7 Pixel Watch 4 rumors I’m most curious about

      July 22, 2025

      8 ways I quickly leveled up my Linux skills – and you can too

      July 22, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025
      Recent

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025

      Zero Trust & Cybersecurity Mesh: Your Org’s Survival Guide

      July 22, 2025

      Execute Ping Commands and Get Back Structured Data in PHP

      July 22, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025
      Recent

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025

      “I don’t think I changed his mind” — NVIDIA CEO comments on H20 AI GPU sales resuming in China following a meeting with President Trump

      July 22, 2025

      Galaxy Z Fold 7 review: Six years later — Samsung finally cracks the foldable code

      July 22, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»News & Updates»Anchor Positioning Just Don’t Care About Source Order

    Anchor Positioning Just Don’t Care About Source Order

    April 28, 2025

    Ten divs walk into a bar:

    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>
    <div>10</div>

    There’s not enough chairs for them to all sit at the bar, so you need the tenth div to sit on the lap of one of the other divs, say the second one. We can visually cover the second div with the tenth div but have to make sure they are sitting next to each other in the HTML as well. The order matters.

    <div>1</div>
    <div>2</div>
    <div>10</div><!-- Sitting next to Div #2-->
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>

    The tenth div needs to sit on the second div’s lap rather than next to it. So, perhaps we redefine the relationship between them and make this a parent-child sorta thing.

    <div>1</div>
    <div class="parent">
      2
      <div class="child">10</div><!-- Sitting in Div #2's lap-->
    </div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>

    Now we can do a little tricky positioning dance to contain the tenth div inside the second div in the CSS:

    .parent {
      position: relative; /* Contains Div #10 */
    }
    
    .child {
      position: absolute;
    }

    We can inset the child’s position so it is pinned to the parent’s top-left edge:

    .child {
      position: absolute;
      inset-block-start: 0;
      inset-inline-start: 0;
    }

    And we can set the child’s width to 100% of the parent’s size so that it is fully covering the parent’s lap and completely obscuring it.

    .child {
      position: absolute;
      inset-block-start: 0;
      inset-inline-start: 0;
      width: 100%;
    }

    Cool, it works!

    CodePen Embed Fallback

    Anchor positioning simplifies this process a heckuva lot because it just doesn’t care where the tenth div is in the HTML. Instead, we can work with our initial markup containing 10 individuals exactly as they entered the bar. You’re going to want to follow along in the latest version of Chrome since anchor positioning is only supported there by default at the time I’m writing this.

    <div>1</div>
    <div class="parent">2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>
    <div class="child">10</div>

    Instead, we define the second div as an anchor element using the anchor-name property. I’m going to continue using the .parent and .child classes to keep things clear.

    .parent {
      anchor-name: --anchor; /* this can be any name formatted as a dashed ident */
    }

    Then we connect the child to the parent by way of the position-anchor property:

    .child {
      position-anchor: --anchor; /* has to match the `anchor-name` */
    }

    The last thing we have to do is position the child so that it covers the parent’s lap. We have the position-area property that allows us to center the element over the parent:

    .child {
      position-anchor: --anchor;
      position-area: center;
    }

    If we want to completely cover the parent’s lap, we can set the child’s size to match that of the parent using the anchor-size() function:

    .child {
      position-anchor: --anchor;
      position-area: center;
      width: anchor-size(width);
    }
    CodePen Embed Fallback

    No punchline — just one of the things that makes anchor positioning something I’m so excited about. The fact that it eschews HTML source order is so CSS-y because it’s another separation of concerns between content and presentation.


    Anchor Positioning Just Don’t Care About Source Order originally published on CSS-Tricks, which is part of the DigitalOcean family. You should get the newsletter.

    Source: Read More 

    Facebook Twitter Reddit Email Copy Link
    Previous ArticleNVIDIA Riva Vulnerabilities Leave AI-Powered Speech and Translation Services at Risk
    Next Article GitHub for Beginners: Building a REST API with Copilot

    Related Posts

    News & Updates

    The best CRM software with email marketing in 2025: Expert tested and reviewed

    July 22, 2025
    News & Updates

    This multi-port car charger can power 4 gadgets at once – and it’s surprisingly cheap

    July 22, 2025
    Leave A Reply Cancel Reply

    For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

    Continue Reading

    Cookie pop-ups don’t have to be a fact of life online – how I block them and why

    News & Updates

    CVE-2024-47065 – Meshtastic Traceroute Rate Limiting Vulnerability

    Common Vulnerabilities and Exposures (CVEs)

    Cisco Warns of Credential Vuln on AWS, Azure, Oracle Cloud

    Security

    CVE-2024-58250 – ppp Passprompt Privilege Escalation Vulnerability

    Common Vulnerabilities and Exposures (CVEs)

    Highlights

    From Concept to Code: Final Year PHP Projects with Reports for Smart Submissions

    June 16, 2025

    At PHPGurukul, we know the importance of your final year project—both as an assignment, but…

    ChatGPT can now sum up your meetings – here’s how to use it (and who can)

    June 21, 2025

    The next big HDMI leap has arrived – here’s how these 16K cables will shake things up

    June 27, 2025

    CVE-2025-6168 – GitLab EE Group-level User Invitation Bypass Vulnerability

    July 10, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.