-
Notifications
You must be signed in to change notification settings - Fork 772
fxHide API
The fxHide directive allows developers to dynamically and/or responsively show/hide the hosting element. The fxHide logic defaults to hiding 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.
- fxHide.lg, etc.
- fxShow.gt-sm,
- fxHide (without a value) means "display:none"
- fxShow (without a value) means use the origin display style value
- fxHide="false" means use the original display value (should no longer be hidden)
- fxShow="false" means "display:none" and hide it.
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..
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