Is it somehow possible to style an iframes before/after pseudo-element?

前端 未结 2 1708
醉话见心
醉话见心 2021-02-18 20:32

As the title says, is there a way to style an iframes pseudo before/after? Without wrapping the iframe with another div, or else?`

相关标签:
2条回答
  • 2021-02-18 20:57

    Direct Work-Around for Debugging Purposes

    I have a debugging CSS tier that gives an outline to elements with invalid or obsolete code. While not exactly an answer someone may find it helpful as I was trying to find a way to visually ensure that any content embedded with an iframe had an allowfullscreen="true" attribute/value. This work-around uses a sibling selector and it works well-enough.

    iframe:not([allowfullscreen]) + *::after
    {
     background-color: #f00;
     border: #f00 solid 4px;
     color: #fff;
     content: 'Missing allowfullscreen attribute on iframe!' !important;
     font-size: 24px;
     padding: 4px;
    }
    

    Direct Styling using Third Element

    If you're looking to position relative to the iframe my next recommendation would be to set the iframe's parent position to position: relative; and then set position: absolute; on a third element to match the iframe's rendering. Lastly you could finally apply the ::after on that third element.

    0 讨论(0)
  • 2021-02-18 21:06

    I am not sure but I think it isn't possible. Or the logic behind an iframe makes it imposible to achieve.

    As you know, pseudo-elements are added to its container, if you do that with an iframe, pseudo-elements would be added inside the iframe. But, and here's the problem, the iframe content, the inline content, will just load if the browser doesn't support iframes.

    This means that this:

    <iframe>
      <div>Your browser doesn't support iframes</div>
    </iframe>
    

    And adding pseudo-elements, will do the same thing; on modern browsers inline content wouldn't be displayed.

    0 讨论(0)
提交回复
热议问题