-
Notifications
You must be signed in to change notification settings - Fork 772
fxShow API
The fxShow directive allows developers to dynamically and/or responsively show/hide the hosting element. The fxShow logic defaults to showing an element.
-
Flex-Layout supports STATIC API for responsive layouts using the API without
.<xxx>
alias suffixes: fxShow, fxHide, etc. These values of these directives are used (and styles applied) regardless of the viewport size. These static rules can be specifically overridden by a registered responsive API use (see below). -
Flex-Layout provides a RESPONSIVE API for dynamic adaptive layouts. This is simply using the the static API with mediaQuery alias suffixes. e.g.
- fxShow.gt-sm,
- fxHide.lg, etc.
- fxShow (without a value) means use the origin display style value
- fxHide (without a value) means "display:none"
- fxShow="false" means "display:none" and hide it.
- fxHide="false" means use the original display value (should no longer be hidden)
fxHide is the inverse of fxShow
When a mediaQuery range activates, the directive instances will be notified. If the current activate mediaQuery range (and its associated alias) are not used, then the static API value is restored as the fallback value.
The fallback solution uses a largest_range-to-smallest_range
search algorithm. Consider the following:
<div fxShow.sm="false" fxShow.gt-md="false" fxShow="true" ></div>
- When the
lg
range is activated (by viewport resizing,etc) the div is hidden since thegt-md
is used as the closest descending fallback value. - When the
md
range is activated, the div is shown since the static API is the closest descending matching condition. - When the
sm
range is activated the div is hidden.
Please note that there is no left-to-right precedence. This is an incorrect interpretation..
When multiple overlapping breakpoint aliases are used, the one with the largest range wins.
Consider:
<div fxShow="true" fxShow.gt-xs="true" fxShow.gt-md="false" ></div>
When the media range for md
activates, then both gt-md
and gt-xs
responsive usages ^ will match. But gt-xs
matches last so that value will be used and therefore the div element will be shown.
We can leverage the default values of these directives select specific conditions when an element is hidden or shown.
Consider:
<div fxHide fxShow.gt-sm></div>
means the the above element will be hidden by default and ONLY shown on viewport sizes greater than mobile.
<div fxShow fxHide.md ></div>
means the the above element will be shown by default and ONLY hidden on viewport sizes == md
mediaQuery ranges.
-
Quick Links
-
Documentation
-
Demos
-
StackBlitz Templates
-
Learning FlexBox
-
History
-
Developer Guides
-
Contributing