- How To Use Cards And Tiles On Your Website Page
- How To Use Cards And Tiles On Your Website Free
- How To Use Cards And Tiles On Your Website Page
- How To Use Cards And Tiles On Your Website Free
Without relying on tables, what would be a good solution to accomplish a tile layout such as this: that automatically adapts to the screen size of the user. That is, the whole screen should be filled by the tiles, regardless of the with and height of the resolution. A tile is a snapshot of your data, pinned to the dashboard. A tile can be created from a report, dataset, dashboard, the Q&A box, Excel, SQL Server Reporting Services (SSRS) reports, and more. This screenshot shows many different tiles pinned to a dashboard. Dashboards and dashboard tiles are a feature of Power BI service, not Power BI Desktop. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may have an effect on your browsing experience.
HOW TO
HowTo HomeMenus
Icon BarMenu IconAccordionTabsVertical TabsTab HeadersFull Page TabsHover TabsTop NavigationResponsive TopnavNavbar with IconsSearch MenuSearch BarFixed SidebarSide NavigationResponsive SidebarFullscreen NavigationOff-Canvas MenuHover Sidenav ButtonsSidebar with IconsHorizontal Scroll MenuVertical MenuBottom NavigationResponsive Bottom NavBottom Border Nav LinksRight Aligned Menu LinksCentered Menu LinkEqual Width Menu LinksFixed MenuSlide Down Bar on ScrollHide Navbar on ScrollShrink Navbar on ScrollSticky NavbarNavbar on ImageHover DropdownsClick DropdownsCascading DropdownDropdown in TopnavDropdown in SidenavResp Navbar DropdownSubnavigation MenuDropupMega MenuMobile MenuCurtain MenuCollapsed SidebarCollapsed SidepanelPaginationBreadcrumbsButton GroupVertical Button GroupSticky Social BarPill NavigationResponsive HeaderImages
SlideshowSlideshow GalleryModal ImagesLightboxResponsive Image GridImage GridTab GalleryImage Overlay FadeImage Overlay SlideImage Overlay ZoomImage Overlay TitleImage Overlay IconImage EffectsBlack and White ImageImage TextImage Text BlocksTransparent Image TextFull Page ImageForm on ImageHero ImageBlur Background ImageChange Bg on ScrollSide-by-Side ImagesRounded ImagesAvatar ImagesResponsive ImagesCenter ImagesThumbnailsBorder Around ImageMeet the TeamSticky ImageFlip an ImageShake an ImagePortfolio GalleryPortfolio with FilteringImage ZoomImage Magnifier GlassImage Comparison SliderButtons
Alert ButtonsOutline ButtonsSplit ButtonsAnimated ButtonsFading ButtonsButton on ImageSocial Media ButtonsRead More Read LessLoading ButtonsDownload ButtonsPill ButtonsNotification ButtonIcon ButtonsNext/prev ButtonsMore Button in NavBlock ButtonsText ButtonsRound ButtonsScroll To Top ButtonForms
Login FormSignup FormCheckout FormContact FormSocial Login FormRegister FormForm with IconsNewsletterStacked FormResponsive FormPopup FormInline FormClear Input FieldHide Number ArrowsCopy Text to ClipboardAnimated SearchSearch ButtonFullscreen SearchInput Field in NavbarLogin Form in NavbarCustom Checkbox/RadioCustom SelectToggle SwitchCheck CheckboxDetect Caps LockTrigger Button on EnterPassword ValidationToggle Password VisibilityMultiple Step FormAutocompleteTurn off autocompleteTurn off spellcheckFile Upload ButtonEmpty Input ValidationFilters
Filter ListFilter TableFilter ElementsFilter DropdownSort ListSort TableTables
Zebra Striped TableCenter TablesFull-width TableSide-by-side TablesResponsive TablesComparison TableMore
Fullscreen VideoModal BoxesDelete ModalTimelineScroll IndicatorProgress BarsSkill BarRange SlidersTooltipsDisplay Element HoverPopupsCollapsibleCalendarHTML IncludesTo Do ListLoadersStar RatingUser RatingOverlay EffectContact ChipsCardsFlip CardProfile CardProduct CardAlertsCalloutNotesLabelsCirclesStyle HRCouponList GroupList Without BulletsResponsive TextCutout TextGlowing TextFixed FooterSticky ElementEqual HeightClearfixResponsive FloatsSnackbarFullscreen WindowScroll DrawingSmooth ScrollGradient Bg ScrollSticky HeaderShrink Header on ScrollPricing TableParallaxAspect RatioResponsive IframesToggle Like/DislikeToggle Hide/ShowToggle Dark ModeToggle TextToggle ClassAdd ClassRemove ClassActive ClassTree ViewRemove PropertyOffline DetectionFind Hidden ElementRedirect WebpageZoom HoverFlip BoxCenter VerticallyCenter Button in DIVTransition on HoverArrowsShapesDownload LinkFull Height ElementBrowser WindowCustom ScrollbarHide ScrollbarShow/Force ScrollbarDevice LookContenteditable BorderPlaceholder ColorText Selection ColorBullet ColorVertical LineDividersAnimate IconsCountdown TimerTypewriterComing Soon PageChat MessagesPopup Chat WindowSplit ScreenTestimonialsSection CounterQuotes SlideshowClosable List ItemsTypical Device BreakpointsDraggable HTML ElementJS Media QueriesSyntax HighlighterJS AnimationsJS String LengthJS Default ParametersGet Current URLGet Current Screen SizeGet Iframe ElementsWebsite
Make a WebsiteMake a Website (W3.CSS)Make a Website (BS3)Make a Website (BS4)Make a WebBookCenter WebsiteContact SectionAbout PageBig HeaderExample WebsiteGrid
2 Column Layout3 Column Layout4 Column LayoutExpanding GridList Grid ViewMixed Column LayoutColumn CardsZig Zag LayoutBlog LayoutConverters
Convert WeightConvert TemperatureConvert LengthConvert Speedby Nathan Rohler
As we looked at in a recent article (Responsive Design: A Crash Course and Demo), responsive design is becoming the favored approach for making your site accessible on all devices. One of the main reasons that this approach is gathering significantly more steam than adaptive design (presenting an entirely separate mobile-optimized site) is the incredible diversity of devices popping up, each having a unique screen size and resolution. When we only had to worry about smartphones, there were two distinct classes of devices – phones and desktops/laptops. Now, however, we have phones, phablets, mini tablets, average tablets, giant tablets, netbooks, little desktops, big desktops, etc, on and on. Going responsive is relatively easy, and ensures forward compatibility with whatever next generation of devices comes down the pike. Also, let's not kid ourselves – part of the appeal of responsive design is that it's so knock-your-socks-off cool when done well. (In case you're looking for some great examples, check out mediaqueri.es.)
If you're new to responsive design and haven't seen the article I mentioned a moment ago, I recommend you review it now to get up to speed on media queries, the foundation on which responsive design is built. In that article, we focused on adjusting element widths and modifying the layout as the window resized. But what about adjusting heights along with the widths? And what about putting it together in a tiled layout? That's what we're going to look at today. We'll create a tiled photo gallery to learn these principles.
First, here's the demo of what we're going to create (source code here). Resize your browser window and watch the tile size grow and shrink to fit the available space. At certain points, you'll notice that the layout 'snaps' to a new number of tiles per row. If you have a smartphone or tablet, try loading the page there too:
How To Use Cards And Tiles On Your Website Page
Psst! Looking for a ready-made solution to save time? Check out our new Hummingbird Photo Gallery plugin for WordPress.
Making Responsive Squares
The foundation of our project is responsive squares – that is, squares that automatically resize, both horizontally and vertically, based on the layout. We start by using a percentage-based width for a div. For example, let's make a box with width: 25%
. Twenty-five percent of what, you ask? The parent container's width. If we place that box directly in the <body>
of a page, here's what we have (view source):
Now, suppose that we add height: 25%;
to the CSS and preview again:
That's no mistake – it looks just the same as before. This is because height
percentages are based on the vertical height of the container (in this case, the <body>
). But because the box is the only content in its parent, the height is based on a percentage of itself (which doesn't make any sense). We can avoid this by adding the following special CSS that tells the <body>
to base its height on the browser window's height:
Adding that declaration yields the following (view source):
If you resize your browser window, you'll notice how the box's height is now tied to the window's height. That's nice, but we want our box to be square, with the height matching the width. The trick is to use the padding-bottom
property instead of the height
property. Padding values are based on the container's width, the same as the width
property is. If we use width: 25%
and padding-bottom: 25%
, here's what we get (view source):
If you resize your browser window horizontally, you'll notice that the box remains a square, always adjusting both dimensions together. Perfect, right? But it's a little more complicated than that. (You knew I was going to say that, didn't you!) As you may notice, I removed the text from the box for this demo. That's because the actual height of the box is based on padding-bottom
plus the height of any content in the box. If I had left the text, the box would have been too tall:
But if we place the content inside another div
with position: absolute
applied, it won't be counted when the box height is calculated. To use absolute positioning on the content div
, we have to also apply position: relative
to the parent. This makes the absolute positioning relative to the parent box instead of the entire page. Here's what we now have (view source):
To review, here's the HTML and CSS we now have:
I've added 10 pixels of spacing on each edge to help you see what's happening, but we could use 0 and there would be no way to tell that two boxes are actually in use. A side-benefit of using the absolute positioning is that we can also apply padding and borders to the inner box without affecting the outer box's size. (Note: There's a way to do this with the experimental box-sizing
property, but our method is backward-compatible.)
Creating a Grid
We've successfully created a resizable square using nothing but CSS. The next step is to turn this into a grid. That's as simple as placing several boxes within a 'wrapper' that has overflow: hidden
, then setting float: left
on each box:
View the demo here and resize your window to see how the tiles expand and contract. (Full source here.)
Making the Grid Responsive
Now we have a grid; but on a small screen, the tiles are tiny and the contents are cut off, and on a large screen, the tiles are huge. We're ready to make the grid responsive with media queries. To modify the number of tiles per row, all we need to change is the width
and padding-width
of each box. The following CSS creates 'breakpoints' at 480 pixels, 650 pixels, 1050 pixels and 1290 pixels (all representative of common screen sizes):
These breakpoints ensure that the tiles' size always remains within a comfortable range. We'll also update the default width
and padding-bottom
properties for .box
to be 20%
(5 tiles); this is what will be shown for large screens.
To enable media query compatibility for IE8 and older, we have to add the following code after the CSS:
Note: Best practices dictate you should download the referenced file and save it to your site, then link to that local version. We're hotlinking just for the sake of simplicity in this demo.
View the final demo here; again, resize your browser window to see the grid snap. When your browser window is very narrow, there will be only 1 tile. As you expand the width, the number of tiles will grow until it reaches 5. The full source is here.
Putting It All Together
Now that you know how to create a responsive grid of square tiles, we'll apply those skills in a practical and fun way to create the photo gallery you saw at the beginning of the tutorial. Our photos are 460 pixels square, which ensures that they are scaled down slightly except on the largest of screens. This way, the photos always will look crisp.
Additionally, we have a title box that appears over each photo when it is hovered-over (or tapped on a touchscreen).
The HTML
Start with a basic HTML5 page:
First, add the following <meta>
tag just inside the opening <head>
tag:
This line, which is very important, tells mobile browsers to not scale the page by default. This allows our media queries to be applied instead of the default 'scale the page way down' behavior.
Next, let's add the markup that defines all of the tiles. Add the following HTML within the <body>
of your page:
Note that we place all content within a wrapper, <div>
, and that each tile is defined with the following code:
The CSS
If you preview your page now, you'll see just a linear list of photos. Style the page by adding the following CSS inside the <style>
tag:
Here is a commented version of that code, to help you understand what each part does:
And a Little JavaScript...
As I mentioned earlier, media queries only function in Internet Explorer version 9 and higher by default. To work around this, we need to add the helpful css3-mediaqueries.js
script immediately following the <style>
tag in the page's <head>
:
Again, you should download the referenced file and save it to your site, then link to that local version. Note that the code is wrapped in a conditional IE comment, which ensures that we don't waste loading time in browsers where native media query support is available.
The layout is now complete (as you'll see by previewing), but the title boxes aren't yet enabled. This is because we want to enable slightly different behaviors for traditional computers and touchscreens. On desktops/laptops, we want the title to appear when hovering over a photo. On touchscreens, we want to toggle the title on and off by tapping on a photo. To enable this, first add the no-touch
class to the <body>
tag:
If you preview now on a desktop/laptop, you'll see that the titles now appear when hovering over an image. To enable the touchscreen behavior, however, we need to add the following chunk of JavaScript at the end of the page, just before the closing </body>
tag:
This JavaScript code (which uses the jQuery library) switches out the no-touch
class with the touch
class on the body
tag when viewing on a touchscreen device. It also adds a listener for taps on the photos, toggling the touchFocus
CSS class we defined earlier whenever a tap occurs.
Tip: If you're new to JavaScript and jQuery, check out Eloquent JavaScript and jQuery Fundamentals, two excellent and free eBooks linked in this article.
If you preview again now (full-window view), your tiled photo gallery should be fully functional on all devices and browsers.
How To Use Cards And Tiles On Your Website Free
Conclusion
In this article, you learned the necessary skills to create resizable square tiles and place them in a responsive tiled grid. To review, here are all of the techniques we've used along the way:
- Creating flexible-size CSS tiles (using
width
andpadding-bottom
in combination with an inner absolutely-positioned content area) - Building a responsive layout by using CSS media queries
- Using the
css3-mediaqueries.js
script to enable media query compatibility for old IE versions - Using CSS floats and relative+absolute positioning
- Enhancing our page with CSS3 transitions (to show/hide the title box)
- Enabling enhanced touchscreen functionality with JavaScript/jQuery
How To Use Cards And Tiles On Your Website Page
We used these techniques to create a photo gallery, but they are applicable to countless other types of projects too. How will you use them?
How To Use Cards And Tiles On Your Website Free
(And just a reminder – if you want to easily create tiled galleries with a fullscreen view too, check out our new Hummingbird Photo Gallery plugin for WordPress.)