how to create a content navigator with CSS only. The idea is to have several slides or content layers that we’ll show or hide using the :target pseudo-class. With CSS transitions we can make the slides appear in a fancy way. We’ll also make the whole thing responsive.
The images used in the demo are by super-talented Karrie Nodalo. Check out her Flickr photostream. The images are licensed under the Creative Commons Attribution 2.0 Generic License.
Please note: the result of this tutorial will only work as intended in browsers that support the CSS properties in use.
The Markup
For each of the different slides that will either contain a set of links, sub-slides or some content, we will have a division with the class cn-slide. For the sub-slide that will contain two link boxes in a row we’ll add another class called cn-slide-sub. The content slides will simply have the general class cn-slide like all the others.
There will be one main slide that will have links to three sub-slides. Then, each of the sub-slides will have four links, each one pointing to a content slide. So, all together we have one main slide, three sub-slides and twelve content slides:
<section class="cn-container">The sub-slides and the slides with content will have a link back to their previous “layer”. So, all the content slides of the “Philosophy” part will link back to “slide-1″ which is the sub-slide of “Philosophy”.
<div class="cn-slide" id="slide-main">
<h2>Explore this</h2>
<nav>
<a href="#slide-1">Philosphy</a>
<a href="#slide-2">Science</a>
<a href="#slide-3">Literature</a>
</nav>
</div>
<!-- Slide 1 and sub-slides -->
<div class="cn-slide ts-slide-sub" id="slide-1">
<h2>Philosophy</h2>
<a href="#slide-main" class="cn-back">Back</a>
<nav>
<a href="#slide-1-1">Epistemology</a>
<a href="#slide-1-2">Metaphysics</a>
<a href="#slide-1-3">Aesthetics</a>
<a href="#slide-1-4">Ethics</a>
</nav>
</div>
<div class="cn-slide" id="slide-1-1">
<h2>Epistemology</h2>
<a href="#slide-1" class="cn-back">Back</a>
<div class="cn-content">
<p>Some text</p>
</div>
</div>
<div class="cn-slide" id="slide-1-2">
<h2>Metaphysics</h2>
<!-- ... -->
</div>
<div class="cn-slide" id="slide-1-3">
<!-- ... -->
</div>
<div class="cn-slide" id="slide-1-4">
<!-- ... -->
</div>
<!-- Slide 2 and Sub-slides -->
<!-- ... -->
</section>
Let’s take a look at the CSS!
The CSS
.cn-container{The main headline will be placed absolutely and we will make it fade in and scale up when “opening” a slide. The transition will have a delay because we want it to appear after all the link boxes:
width: 60%;
min-width: 300px;
max-width: 820px;
margin: 10px auto 0 auto;
text-align: left;
position: relative;
}
.cn-container h2{The slides will also be placed absolutely. We’ll set the initial opacity of the slides to 0 and show it once we know that it’s the target:
font-family: 'BebasNeueRegular', 'Arial Narrow', Arial, sans-serif;
color: #fff;
position: absolute;
z-index: 10000;
text-shadow:
0 0 1px rgba(255,255,255,0.8),
1px 1px 1px rgba(0,0,0,0.2);
font-size: 80px;
line-height: 80px;
top: 0px;
right: 0px;
white-space: nowrap;
opacity: 0;
transform: scale(0);
transition: all 0.5s linear 0.7s;
}
.cn-container .cn-slide:target h2{
opacity: 1;
transform: scale(1);
}
.cn-slide{Note that in some other demos we are using the transitions on the slides. Here we will use sequential transitions on the link elements.
text-align: center;
position: absolute;
left: 0px;
padding-top: 80px;
margin: 0 5%;
width: 90%;
opacity: 0;
}
.cn-slide:target{
opacity: 1;
z-index: 1000;
}
Now, let’s take a look at the link elements. They will all have a single background image which we will later define for each element. By default, we’ll give 1.jpg as the background image. Initially, the opacity and scale will be 0. We add a transition for the two properties and also for the box-shadow which we need when we hover the element:
.cn-slide nav a{The target slide’s link elements will fade in and scale up to 1:
text-align: left;
display: block;
font-family: 'BebasNeueRegular', 'Arial Narrow', Arial, sans-serif;
border: 8px solid #fff;
padding: 2%;
font-size: 66px;
letter-spacing: 7px;
text-shadow: 0px 5px 0px rgba(182,105,135,0.4);
color: #fff;
line-height: 66px;
outline: none;
margin: 0 0 10px 0;
box-shadow: 1px 1px 3px rgba(0,0,0,0.1);
background: #fff url(../images/1.jpg) no-repeat center center;
background-size: 100%;
background-clip: padding-box;
opacity: 0;
transform: scale(0);
transition:
opacity 0.4s linear,
transform 0.4s linear,
box-shadow 0.3s ease-in-out;
}
.cn-slide nav a:hover{
box-shadow: 1px 2px 4px rgba(0,0,0,0.2);
}
.cn-slide:target nav a{Let’s define a transition delay for the elements, so that they appear one after the other:
opacity: 1;
transform: scale(1);
}
.cn-slide nav a:nth-child(2){As you can see, the last delay will be of 0 seconds since this is the delay for the box-shadow transition, the one that get’s applied on hover.
transition-delay: 0.3s, 0.3s, 0s;
}
.cn-slide nav a:nth-child(3){
transition-delay: 0.6s, 0.6s, 0s;
}
.cn-slide nav a:nth-child(4){
transition-delay: 0.9s, 0.9s,0s;
}
The link elements in the sub-slides will have a width of 42% because we want two to fit into a row:
.cn-slide-sub nav a{To create a little gap between the elements, we’ll give a right margin to the odd children:
width: 42%;
display: inline-block;
font-size: 40px;
}
.cn-slide-sub nav a:nth-child(odd){The slides with a content area are the “final” ones and we’ll also add a transition to that division:
margin-right: 5px;
}
.cn-content{Each content area will, just like their corresponding link elements, have a background image that we will define later.
background: #80B8CE url(../images/1.jpg) no-repeat center center;
background-size: cover;
text-align: left;
padding: 20px 20px 5px;
box-shadow: 1px 1px 3px rgba(0,0,0,0.1);
border: 8px solid #fff;
margin-top: 5px;
cursor: pointer;
opacity: 0;
transform: scale(0);
transition: all 0.6s linear;
}
.cn-slide:target .cn-content{
opacity: 1;
transform: scale(1);
}
The paragraphs will also have a transition which will be applied when we click on the content. With the :active pseudo-class we can let the user view the background of the content div by clicking on it (and keeping it clicked):
.cn-content p{The back arrow will be sliding in from the left. We set it to -100px initially and to 3px when a slide is the target:
line-height: 24px;
text-shadow: 1px 1px 1px rgba(255,255,255,0.9);
color: rgba(103,59,77,0.9);
padding: 15px 20px;
margin-bottom: 10px;
background: rgba(255,255,255,0.96);
font-style: italic;
border-top: 7px solid rgba(103,59,77,0.6);
user-select: none;
transform: scale(1);
transition: all 0.3s linear;
}
.cn-content:active p{
transform: scale(0);
}
.cn-back{Now, let’s define the background images for each link element. With the very helpful attribute selector, we can specify which element will have what background image. We will look at what the href value is and define the image:
outline: none;
text-indent: -9000px;
width: 49px;
height: 42px;
background: transparent url(../images/arrow.png) no-repeat center center;
position: absolute;
top: 22px;
left: -100px;
cursor: pointer;
opacity: 0;
transition: all 0.4s ease-in-out 1s;
}
.cn-slide:target .cn-back{
left: 3px;
opacity: 1;
}
/* Main Items */Finally, we will define some media queries to fix the layout when we view this on a smaller screen. You can of course define the standard media queries for common devices but here we will simply check when our liquid layout breaks and define a rule for that “breaking-point”. In our case, that’s 1060 pixel and 900 pixel. We will adjust the font size and allow the sub-slides to have one item in a row:
.cn-slide nav a[href="#slide-1"]{
background-image: url(../images/1.jpg);
}
.cn-slide nav a[href="#slide-2"]{
background-image: url(../images/2.jpg);
}
.cn-slide nav a[href="#slide-3"]{
background-image: url(../images/3.jpg);
}
/* Items and sub-items of slide 1*/
.cn-slide nav a[href="#slide-1-1"],
#slide-1-1 .cn-content {
background-image: url(../images/4.jpg);
}
.cn-slide nav a[href="#slide-1-2"],
#slide-1-2 .cn-content {
background-image: url(../images/5.jpg);
}
.cn-slide nav a[href="#slide-1-3"],
#slide-1-3 .cn-content {
background-image: url(../images/6.jpg);
}
.cn-slide nav a[href="#slide-1-4"],
#slide-1-4 .cn-content {
background-image: url(../images/7.jpg);
}
/* Items and sub-items of slide 2 ... */
/* ... */
/* Items and sub-items of slide 3 ... */
/* ... */
@media screen and (max-width: 1060px){
.cn-slide-sub nav a{
font-size: 28px;
}
}
@media screen and (max-width: 900px){
.cn-container h2{
font-size: 48px;
line-height: 95px;
}
.cn-slide nav a{
font-size: 38px;
}
.cn-slide-sub nav a{
width: auto;
font-size: 36px;
display: block;
}
.cn-slide-sub nav a:nth-child(odd){
margin-right: 0px;
}
}
0 comments:
Post a Comment