Create A Simple Responsive Portfolio Page with Filtering and Hover Effect (Updated)

Written by Kevin Liew on 29 Apr 2016
574,373 Views • Tutorials

Previously, I was showing how to create portfolio page with filtering and also hover effect for each of your project item. We achieved that effect with CSS3 and jQuery filter & sort plugin called MixItUp.

The response was pretty good, it has been in our popular post list for quite sometimes too. I guess it's due to the fact that filtering UI is quite a popular thing to implement. So, I was looking at the comment, I think I need to do an update and fix some of the issues.

Alright, this time it's not just fixing the issues but with some enhancements as well. Here's the updates:

  • MixItUp is now version 2.1.11, the one we used is way outdated. The good news is, the new one can load your desired filter on first run, not just showing all of it.
  • Easing plugin is removed and replaced with CSS3 transition instead. We can achieve the same thing with smaller file size and less JS. So, why not?
  • There're a couple of comments mentioned there's a bug that causing the whole thing moved 3-4px to the left. It's actually not an issue, because when you show ALL, the content became longer. Therefore, in IE you have a scrollbar displayed on the right which causing the undesired sudden movement that moves everything to the left. I didn't see this because I'm on Mac and scrollbar hover above the content instead of taking up the website viewport space.

I'm trying to keep everything the same so you can update it easily. This script will work pretty well with our previously published tutorial - display images with shape masking and nifty zoom effect.

Alright, lets get it started. First of all this is the screenshot of what we are about to build:

Based on the layout there are two main UI elements we need to build - Tab navigation for filtering and a grid of portfolio with hover effect. After that we will hook it up with MixItOut and our custom hover script.

HTML

First of all, we have the HTML markup for Tab navigation. It's a UL list with data filter. data-filter is included because MixItUp needs it for its filtering. It's updated to conform to the new MixItUp formatting. Classes are specified in data-filter to be consistent with jQuery filter()

<ul id="filters" class="clearfix">
<li><span class="filter active" data-filter=".app, .card, .icon, .logo, .web">All</span></li>
<li><span class="filter" data-filter=".app">App</span></li>
<li><span class="filter" data-filter=".card">Card</span></li>
<li><span class="filter" data-filter=".icon">Icon</span></li>
<li><span class="filter" data-filter=".logo">Logo</span></li>
<li><span class="filter" data-filter=".web">Web</span></li>
</ul>

Under the Tab navigation, we have portfolio list. We need to assign each portfolio a category in data-cat attribute. By matching data-filter with data-cat, this is how MixItUp filters portfolios.

Other than that, we added label and hide it by default. We will show it on mouse hover with CSS3.

<div id="portfoliolist">
  <div class="portfolio logo" data-cat="logo">
    <div class="portfolio-wrapper">
      <img data-src="img/portfolios/logo/5.jpg" alt="" />
      <div class="label">
        <div class="label-text">
          <a class="text-title">Bird Document</a> 
          <span class="text-category">Logo</span>
        </div>
        <div class="label-bg"> </div>
      </div>
    </div>
  </div>
.........
</div>

CSS

We divided CSS into two parts - general styling for UI elements and responsive.

html {
  overflow-y: scroll;
}

.container { 
	position: relative; 
	width: 960px; 
	margin: 0 auto; 
	-webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -o-transition: all 1s ease;
  transition: all 1s ease;	
}
 
#filters {
	margin:1%;
	padding:0;
	list-style:none;
}

	#filters li {
		float:left;
	}
	
	#filters li span {
		display: block;
		padding:5px 20px;		
		text-decoration:none;
		color:#666;
		cursor: pointer;
	}
	
	#filters li span.active {
		background: #e95a44;
		color:#fff;
	}
 

 
#portfoliolist .portfolio {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	width:23%;
	margin:1%;
	display:none;
	float:left;
	overflow:hidden;
}

	.portfolio-wrapper {
		overflow:hidden;
		position: relative !important;
		background: #666;
		cursor:pointer;
	}

	.portfolio img {
		max-width:100%;
		position: relative;
		top:0;
    -webkit-transition: all 600ms cubic-bezier(0.645, 0.045, 0.355, 1);
    transition:         all 600ms cubic-bezier(0.645, 0.045, 0.355, 1);		
	}
	
	.portfolio .label {
		position: absolute;
		width: 100%;
		height:40px;
		bottom:-40px;
    -webkit-transition: all 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
    transition:         all 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
	}

		.portfolio .label-bg {
			background: #e95a44;
			width: 100%;
			height:100%;
			position: absolute;
			top:0;
			left:0;
		}
	
		.portfolio .label-text {
			color:#fff;
			position: relative;
			z-index:500;
			padding:5px 8px;
		}
			
			.portfolio .text-category {
				display:block;
				font-size:9px;
			}
	
	.portfolio:hover .label {
    bottom:0;
  }
	.portfolio:hover img {
    top:-30px;
  }  

A simple responsive layout to make sure the grid display properly in different window dimension. Removed this bit if you have your own responsive grid system.

/* #Tablet (Portrait) */
@media only screen and (min-width: 768px) and (max-width: 959px) {
	.container {
		width: 768px; 
	}
}

/*  #Mobile (Portrait) - Note: Design for a width of 320px */
@media only screen and (max-width: 767px) {
	.container { 
		width: 95%; 
	}
	
	#portfoliolist .portfolio {
		width:48%;
		margin:1%;
	}		
}

/* #Mobile (Landscape) - Note: Design for a width of 480px */
@media only screen and (min-width: 480px) and (max-width: 767px) {
	.container {
		width: 70%;
	}
}

Javascript

Lastly, we have the Javascript. You can change its setting by visiting its documentation. They have updated it with a lot of explanation and samples. That's a pretty good job. You can check out the animation configuration to see what else effect can you achieve too.

$(function () {
		
	var filterList = {
	
		init: function () {
		
			// MixItUp plugin
			// http://mixitup.io
			$('#portfoliolist').mixItUp({
				selectors: {
  			  target: '.portfolio',
  			  filter: '.filter'	
  		  },
  		  load: {
    		  filter: '.app' // show app tab on first load
    		}     
			});								
		
		}

	};
	
	// Run the show!
	filterList.init();
	
});		

Conclusion

Nowadays, designers tend to cut down the clutters and keep everything simple. With this tutorial, we created a simple filtering portfolio page with hover effect. Sometimes we don't have to reinvent the wheel. With all sort of plugins available today, we can easily produce the effect we want by combining different javascript plugins.

Hopefully this update will solve a lot of questions you have. Drop a comment if you have any questions. Enjoy!

Demo Download
Join the discussion

Comments will be moderated and rel="nofollow" will be added to all links. You can wrap your coding with [code][/code] to make use of built-in syntax highlighter.

133 comments
Ahmad 10 years ago
Thanks for this amazing script
I`ve a question
If i want to display only the first category tab when page loads, not to display the whole categories, how can i do that

Thank you
Reply
Kevin Admin 9 years ago
Yes, this tutorial is updated with latest MixItUp, and it has this feature.
Reply
Jeff Barbosa 10 years ago
Hi Kevin, Thank you very much!! Your tutorial is perfect !!

But still need your kkk help, please ...

I am using the tutorial on a menu of a restaurant web site, are many dishes by category and do not want to use the category 'all' because the site had become too big, someone could help me?
Reply
Kevin Admin 9 years ago
Yes, this tutorial is updated with latest MixItUp. You can choose which filter to be shown by default.
Reply
Nuno 10 years ago
Great tutorial.
How I disable the all filter after init?
Even if my first tab looks like this:

<li><span class="filter active" data-filter="building">Edifício</span></li>

He always shows all images in the first tab.

TIA
Nuno
Reply
Chantelle de Lange 9 years ago
HI,

Thanks so much for this code. I get it to work on it's own but as soon as I add it to my existing site the js gets an error : $(...).mixitup is not a function. And now the filter shows but nothing else... Any ideas?
Reply
Matt 9 years ago
I noticed that this portfolio has problems with a screen resolution of 2560x1440. To fix it I had to set .portfolio width to 17%
Reply
Kim 9 years ago
Has anyone else had an issue with the filters jumping a couple of pixels to the left and then right again everytime you click on a different category? I'm not sure how to resolve this. Please advice! Otherwise everything is working fine, but this is really spoiling it :-( Thanks!!
Reply
Abhijeet 9 years ago
Yes, I am also facing the same problem.
Please, Kevin help us
Reply
Kevin Admin 9 years ago
It's the scrollbar issue in IE. You can fix this by forcing the scroll visible by default in IE. The article is updated with a few enhancements too.


html {
overflow-y: scroll;
}
Reply
Kate Moore 9 years ago
Thanks I love it!
Would it be possible for it to display a specific tab on page load instead of All? I changed the class on the tab I want to "filter active" and re-ordered the list but all of the items still load when you refresh the page instead of the filtered set.
Reply
Kevin Admin 9 years ago
Yes, this tutorial is updated with latest MixItUp, and it has this feature.
Reply
Kam 9 years ago
Hi, I downloaded the package for filter portfolio while when I try to open the Index.html in the folder I can only see the navigation with no images and those button on navigation are none clickable. Also, I saw a message says "Monstroid WordPress Theme on Steroid"

Please let me know how to fix the issue. Thanks a lot.

Kam
Reply
Shane 9 years ago
It has to be uploaded to a server. It works then. As to why I have no idea......
Reply
nihal 9 years ago
hi

its a really helpful tutorial.. and really awesome effect ..

i have used it, but actually i have a problem . everything is working fine in google chrome but its not working in Firefox.

jquery is working fine, but theirs a problem in hover effect

can some1 help
Reply
Kevin Admin 9 years ago
I have tested it on firefox, it's working. Hover effect is now replaced with CSS3 transition, so it should work perfectly now.
Reply
Aldo 9 years ago
Hello, it's a nice plugin, but, how can i change the first filter selected?
for example, when i access the website, the first filter selected is "icon" and not "all".
i tried to put the class "active" on the other filter, but it doesn't work.

ty.
Reply
Heymi kong 9 years ago
I need to implement more than 130 images. Which way is good to set up with backend as a content management system.
Reply
Javid 9 years ago
I cant use it(
Reply
Isabella 9 years ago
I apologize for this silly question...how do I embed this into my Drupal site? A hyperlink to instructions will do - I just don't even know what to search for! Any help would be greatly appreciated.
Reply