Placeholders and Static Position of Abspos Flex Items

Background

  • The impact of absolutely-positioned elements on surrounding content is intended to be nothing; as if the element were not there.
  • The auto position of an absolutely-positioned element is intended to be its position if it were not positioned.
  • There is a tension resulting from these two intentions, with the following options:
    • A. Prioritize the first (invisibility) over the second (static-position accuracy).
    • B. Prioritize the second (static-position accuracy) over the first (invisibility).
    • C. Do something more complicated that tries to satisfy both.

Problem Statement

How should the static position of absolutely-positioned children of a flex container be determined?

Note: This does not affect absolutely-positioned children of a flex item.

Proposal(s)

Proposal A
The static position of the abspos item is the head start corner of the flex container. It has no impact on flex layout.
Proposal B
The static position of an abspos item is centered between the margin edges of the previous and next flex items in the line (need to define edge behavior), and has no impact on flex layout such as justification.
Proposal C
The static position of the abspos item is given by a placeholder anonymous flex item, which impacts layout during justification (space-around/space-between).
Proposal D
The static position of an abspos item is a placeholder anonymous flex item whose position coincides with the margin edge of the subsequent flex item (if any, else the preceding flex item, if any, else the main-start cross-start corner) and has no impact on flex layout such as justification.
Proposal E (C#?)
The static position of the abspos item is given by a placeholder anonymous flex item. The justification space between a preceding flex item and a subsequent placeholder item is suppressed.

Use Cases to Consider

Nobody's come up with a use case for using the static position of an absolutely-positioned flex item. There might be reasons to absolutely-position such a child explicitly and have it not affect layout, however.

Resolution

 
topics/flex-abspos-placeholders.txt · Last modified: 2014/12/09 15:48 by 127.0.0.1
Recent changes RSS feed Valid XHTML 1.0 Valid CSS Driven by DokuWiki