Thursday, 31 December 2015
Wednesday, 30 December 2015
Tuesday, 29 December 2015
Monday, 28 December 2015
Thursday, 24 December 2015
Wednesday, 23 December 2015
Tuesday, 22 December 2015
Monday, 21 December 2015
Friday, 18 December 2015
Thursday, 17 December 2015
Wednesday, 16 December 2015
Tuesday, 15 December 2015
Monday, 14 December 2015
Friday, 11 December 2015
Thursday, 10 December 2015
Wednesday, 9 December 2015
Introducing Term Meta Data In WordPress And How To Use Them
WordPress 4.4 introduced term meta data which allows you to save meta values for terms in a similar way to post meta data. This is a highly anticipated and logical addition to the WordPress system.
So far, the post and comment meta systems allowed us to add arbitrary data to posts and comments. This can be used to add ratings to comments, indicate your mood while you were writing a post, attach prices to product posts, and various other information you think is relevant to your content. As of the newest version of WordPress, meta data can now be added to terms which allows us to create features like default category thumbnails in a standardized way. This tutorial will show you how you can edit, update and retrieve these meta data for terms.
The post Introducing Term Meta Data In WordPress And How To Use Them appeared first on Smashing Magazine.
from Smashing Magazine http://ift.tt/1YYEF7L via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1U3gbr7
Tuesday, 8 December 2015
Monday, 7 December 2015
Sunday, 6 December 2015
Liked on YouTube: Bloons TD Battles - SPENDING SO MUCH CASH & BANANAS BANANZA MODE! - GET MONEY FAST IN BTD BATTLES!
Bloons TD Battles - SPENDING SO MUCH CASH & BANANAS BANANZA MODE! - GET MONEY FAST IN BTD BATTLES!
Bloons td battles - NEW UPDATE & NEW GAME MODE! MOST MONEY EVER IN BTD Battles! BTD Battles BANANZA Match! CAN WE WIN THIS?!! insane late GAME ON NEW GAME MODE! SIGN UP TO FREEMYAPPS HERE FOR FREE ITUNES CARDS! - http://bit.ly/MasterOv About Me: http://bit.ly/15xEg69 I record my iPad using the Elgato HD60 - http://ift.tt/1DLdiki Want To Send Me Stuff!? Here Is My Address: MasterOv Unit 2 Calcote Farm Coate, Devizes SN103LP Want to watch me LiveStream?! Check me out on Kamcord! - http://ift.tt/1jHoFqw Music By MDK! - https://www.youtube.com/user/MDKOfficialYT Music By OMFG! - https://www.youtube.com/channel/UCUYH3xLiTdPkruTWnHmxdnQ https://twitter.com/AlexSavageOMFG
via YouTube http://youtu.be/1L8qgMpD71A
from Tumblr http://ift.tt/1ObrmJu
Friday, 4 December 2015
Thursday, 3 December 2015
Wednesday, 2 December 2015
Tuesday, 1 December 2015
Monday, 30 November 2015
Friday, 27 November 2015
Thursday, 26 November 2015
Wednesday, 25 November 2015
Tuesday, 24 November 2015
Friday, 20 November 2015
Thursday, 19 November 2015
Wednesday, 18 November 2015
Tuesday, 17 November 2015
Sunday, 15 November 2015
Friday, 13 November 2015
Thursday, 12 November 2015
Wednesday, 11 November 2015
Tuesday, 10 November 2015
Monday, 9 November 2015
Sunday, 8 November 2015
RankWyz Tutorial Part 1
This content is for members of webmaster forum. In order to become a member please sign up using the link below. SIGN UP NOW This content is for members of webmaster forum. In order to become a member please sign up using the link below. SIGN UP NOW
The post RankWyz Tutorial Part 1 appeared first on Webmaster Forum.
from WordPress http://ift.tt/1kE4jPR
via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1iMjQvV
Friday, 6 November 2015
Thursday, 5 November 2015
Wednesday, 4 November 2015
Tuesday, 3 November 2015
Monday, 2 November 2015
Saturday, 31 October 2015
Thursday, 29 October 2015
Wednesday, 28 October 2015
Tuesday, 27 October 2015
Monday, 26 October 2015
Sunday, 25 October 2015
Friday, 23 October 2015
Thursday, 22 October 2015
Tuesday, 20 October 2015
Sunday, 18 October 2015
Friday, 16 October 2015
Thursday, 15 October 2015
Wednesday, 14 October 2015
Tuesday, 13 October 2015
Monday, 12 October 2015
Sunday, 11 October 2015
Keyword Canine 3.0 – Review
I have been a user of Jonathan Ledgers The Best Spinner for a number of years now. This tool has proved extremely valuable when it comes to generating content. Check out my The Best Spinner Review if you would like more information. When I found out Jonathan had his own keyword research tool I thought I […]
The post Keyword Canine 3.0 – Review appeared first on Webmaster Forum.
from WordPress http://ift.tt/1K1Kozg
via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1N6OeM4
Friday, 9 October 2015
Thursday, 8 October 2015
Wednesday, 7 October 2015
Tuesday, 6 October 2015
Monday, 5 October 2015
Friday, 2 October 2015
RankWyz Intro Tutorials
RankWyz is a monster of an SEO Tool and has everything you need in order to rank your money sites pages on the first page of the SERPS. The biggest issue that people have is understanding how to use this tool, which is why we have put together a RankWyz tutorial. ×Proofread Part 1 - […]
The post RankWyz Intro Tutorials appeared first on Webmaster Forum.
from WordPress http://ift.tt/1iSbROc
via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1ON56dW
Thursday, 1 October 2015
Wednesday, 30 September 2015
Tuesday, 29 September 2015
Monday, 28 September 2015
Thursday, 24 September 2015
Wednesday, 23 September 2015
Tuesday, 22 September 2015
Monday, 21 September 2015
Friday, 18 September 2015
Thursday, 17 September 2015
Tuesday, 15 September 2015
Monday, 14 September 2015
Friday, 11 September 2015
Thursday, 10 September 2015
Wednesday, 9 September 2015
Tuesday, 8 September 2015
The New Smashing Mystery Riddle: Have You Figured It Out Yet?
Ah, these mystery riddles never stop, do they? To celebrate our ninth birthday, we’ve prepared yet another riddle, and this time it will require a bit more teamwork. We’ve hidden secret keys in different (physical) locations across the world. To move from one level to another, you’ll have to find a hidden print-out in all (four) locations. Watch out for GIF file names.
Tip: Watch out for the file name. Large view.
To find the key password, you have to follow the clues and hints in a series of animated GIFs. Once put together, the keys will add up to a secret Twitter hashtag. Below you’ll find the first animated GIF that contains a location clue. Identify the location, go there (yourself, or ask a friend, colleague or a total stranger) and find a hidden print-out.
The post The New Smashing Mystery Riddle: Have You Figured It Out Yet? appeared first on Smashing Magazine.
from Smashing Magazine http://ift.tt/1UE4lCx via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1JR4FuI
Saturday, 5 September 2015
Friday, 4 September 2015
Thursday, 3 September 2015
Wednesday, 2 September 2015
Tuesday, 1 September 2015
Monday, 31 August 2015
Friday, 28 August 2015
Thursday, 27 August 2015
Tuesday, 25 August 2015
Monday, 24 August 2015
Friday, 21 August 2015
Thursday, 20 August 2015
Tuesday, 18 August 2015
Monday, 17 August 2015
Friday, 14 August 2015
Thursday, 13 August 2015
Tuesday, 11 August 2015
Monday, 10 August 2015
Friday, 7 August 2015
Wednesday, 5 August 2015
Tuesday, 4 August 2015
Monday, 3 August 2015
Friday, 31 July 2015
Wednesday, 29 July 2015
Tuesday, 28 July 2015
Monday, 27 July 2015
Friday, 24 July 2015
Wednesday, 22 July 2015
Tuesday, 21 July 2015
Monday, 20 July 2015
Friday, 17 July 2015
Wednesday, 15 July 2015
Tuesday, 14 July 2015
Quantity Ordering With CSS
Here is your mission, should you choose to accept it: create a table of items. Each item should span a third of the content area, with the fourth item starting on a new row, much like floats. However, a particular item must always display the price at the end of the first row.
So if there are only two elements, the price element would be second. But if there are more than three items, the price would be the last element in the first row.
You might assume that JavaScript would be the best solution — just loop over the items, and if there are more than three, update the styling. But what if I told you could do it with CSS alone?
Pure CSS Counting
I’ve gone all in on flexbox lately, teaching it right alongside floats as a layout method at our little project called HackerYou, and I have found that students take to it well. The flexbox specification contains properties that enable us to modify markup in new ways. One of these is order
, which allows us to modify the presentational order of content without touching the markup or structure.
Used with media queries, order
is extremely useful, enabling us to change the content’s order with the viewport size. That got me thinking: Why can’t we change the order of elements according to the amount of content?
Quantity Queries
An idea explored by Lea Verou1, André Luis2 and Heydon Pickering3, quantity queries count the number of sibling elements and apply styles if a certain number are present.
What if we combined quantity queries and the order
property to change how content is read according to how much of it there is?
Using Flexbox
Flexbox, or the “Flexible Box Layout Module4,” is a CSS specification that allows for content to be laid out in any direction and for children to be sized to their parent easily. Originally introduced in 2009, flexbox has gone through many changes over the years. However, it is supported5 in all current browsers, with the exception of Internet Explorer 9+.
One of the most significant changes within flexbox is the naming syntax of associated properties and values. Because the specification evolved over years, browser vendors would use the syntax that was being developed at the time. So, using vendor prefixes is recommended to ensure support across legacy browsers.
One recommended tool for managing cross-browser support in CSS is Autoprefixer6, which is typically included in preprocessors and Gulp and Grunt files.
Understanding Order
Before we dig into quantity queries and how they work, we should understand how to use the order
property. First, we need to wrap the content with a parent element and apply display: flex
to it.
Here’s the HTML:
<div class="container">
<p class="itemOne">Hello</p>
<p class="itemTwo">World!</p>
</div>
And here’s the CSS:
.container {
display: flex;
}
See the Pen LVVXxz7 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
By default, elements will appear in their order in the markup. All child elements of a flexbox parent share an order
value of 1
.
This value is unitless and simply refers to the order of the element relative to the other elements around it. However, we can change the value of an individual element using the order
property.
p.itemOne {
order: 2;
}
See the Pen Really Good Work Article 10 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
In the example above, we’ve changed the order of p.itemOne
to a value of 2
, making it fall after p.itemTwo
and thereby changing the presentational order for the user. Note that the markup remains the same, however.
Counting With CSS
Media queries, eh? Such an awesome tool for applying CSS when certain conditions are met. Those conditions could be device type, size, color and more — pretty powerful stuff. But the query applies only to the device that the viewer is using; there is no defined CSS method for querying the amount of content in an element.
If we get creative with existing CSS pseudo-selectors, however, we can build tools that count the number of children in an element and then apply styles accordingly. For this example, let’s use a simple ordered list:
<ul class="ellist">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li class="target">6</li>
</ul>
The magic of counting sibling elements is in the selector below. This example applies styles to elements when four or more are available.
ul.ellist li:nth-last-child(n+4) ~ li,
ul.ellist li:nth-last-child(n+4):first-child {
// styles go here
}
See the Pen WvvYyN13 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
Wait, No. That’s Insane!
Yep, that’s the selector. In English, it could be translated as this: “When there are four or more child elements, get the other list items and the first child.”
Let’s break this down. First, the counting:
ul.ellist li:nth-last-child(n+4) {
// Styles!
}
This translates as, “Go to the last child and count back four children.” Apply the styles to the fourth element and all elements before it.
Go ahead and experiment by editing the Codepen and changing the selector to a different number.
See the Pen Pqqvqp16 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
So, there it is, counting. If fewer than four siblings are counted, nothing is selected and no styles are applied. We can now modify this selector to select all li
elements using the general sibling combinator19.
ul.ellist li:nth-last-child(n+4) ~ li {
// Styles!
}
The problem is that this doesn’t select the first child element. We can append another selector to do that:
ul.ellist li:nth-last-child(n+4) ~ li,
ul.ellist li:nth-last-child(n+4):first-child {
// Styles!
}
Of course, we can make the selector more agnostic simply by supplying the parent element and letting it choose all of the children. We do this with the *
selector.
element > *:nth-last-child(n+4) ~ *,
element *:nth-last-child(n+4):first-child {
// Styles!
}
Ordering Based On Quantity
Now that we have explored how to count with CSS selectors and how to use flexbox to order content, let’s mix them together to build a tool that orders elements based on the number of siblings.
Again, we’re trying to make our last element be the third element (i.e. appear as the last element in the first row) when there are more than three siblings.
Let’s apply some CSS for some presentational styling. We’ll apply display: flex
to the parent container, which allows us to apply the order
property on the child elements. As well, we’ll apply some default styling to the .target
element to differentiate it.
ul.ellist {
margin: 20px 0;
padding: 0;
list-style: none;
display: flex;
flex-flow: row wrap;
}
ul.ellist > * {
border: 10px solid #27ae60;
text-align: center;
flex: 1 0 calc(33.33% - 20px);
padding: 20px;
margin: 10px;
}
.target {
color: white;
background: #2980b9;
border: 10px solid #3498db;
}
ul.ellist, ul.ellist > * {
box-sizing: border-box;
}
ul.ellist {
margin: 20px 0;
padding: 0;
list-style: none;
display: flex;
flex-flow: row wrap;
}
ul.ellist > * {
border: 10px solid #27ae60;
text-align: center;
flex: 1 0 calc(33.33% - 20px);
padding: 20px;
margin: 10px;
}
ul.ellist .target {
color: white;
background: #2980b9;
border: 10px solid #3498db;
}
Now that we have a base style to work with, we can create some logic to order our items accordingly. Again, by default, all elements have an order
value of 1
and are displayed according to the order in which they appear in the markup.
Using a quantity query, we can count whether there are more than three items.
ul.ellist > *:nth-last-child(n+3) {
// Styles!
}
We can then modify our query to select the .target
element only if the number of items is met. For now, we’ll apply an order
of -1
, so that it appears at the beginning of our list.
ul.ellist > *:nth-last-child(n+3) ~ .target {
order: -1;
}
Voilà ! We’ve just styled an element based on the numbers of siblings it has. Using this code, we can put one element in front of another.
But what if it needs to go between items?
Some Logical Thinking
Here is the problem, in three arguments:
- By default, all items have an
order
set to1
. We need the items at the beginning of the list to keep thatorder
value. - Our target will be presented at the end of the first row. So, we need the target’s
order
value to be higher than the ones in the beginning — i.e.2
. - We need all items from three onward to have a higher
order
than our target and lead elements. So, they will have anorder
value of3
.
How about this?
Because all items have a default value of 1
, we don’t need to declare that. Let’s allow our target element to have an order
value of 2
via our quantity query, effectively placing it higher than the others.
ul.ellist > *:nth-last-child(n+3) ~ .target {
order: 2;
}
Then, using another quantity query that utilizes nth-child()
, we will count from the beginning of the list, rather than from the end. Because our .target
quantity query is more specific, the last element will be ignored, but all others three and higher will have their order changed.
ul.ellist > *:nth-last-child(n+3) ~ .target {
order: 2;
}
ul.ellist > *:nth-child(n+3) {
order: 3;
}
Whoa! Let’s Go Over That Again
We counted from the end of a parent element if there were a number of child elements. If there were, we applied some styles to an element of our choice. We then counted from the beginning and applied styles to all elements past that point.
The beautiful part is that if we were to remove elements, the target element would still appear in the correct position.
<ul class="ellist">
<li>1</li>
<li>2</li>
<li>3</li>
<li class="target">4</li>
</ul>
The Resulting Task
My first thought when given this task was to use a programming language. Because the website was built on WordPress, I could modify “the loop” to count and inject the element where needed.
However, because I’m building the website for a front-end development school, I wanted to do it with pure CSS and explore the possibilities that flexbox’s order
allows.
Below is an example of the resulting page, done entirely with CSS.
See the Pen Quantity Ordering20 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
Using It In The Real World
Sass
Quantity queries are a fairly new concept, and writing the selectors can be a bit of a challenge. Nevertheless, the community is embracing the concept and is building tools and writing Sass mixins that can help us write queries effectively. Libraries such as the one by Daniel Guillan23, called a Quantity Queries Mixin24, enable us to write media queries as simple includes.
@include at-least($count) { … }
@include between($first, $last) { … }
A plethora of articles also explain the concept and power behind this. James Steinbach25 wrote a great article on “Using Sass for Quantity Queries26.”
PostCSS
PostCSS is a new tool that allows CSS to be transformed with JavaScript. The current PostCSS ecosystem includes many community-developed plugins, including a Quantity Query27 plugin.
The plugin allows for custom pseudo-selectors to target values within a certain range, at least, or at most.
p:at-least(4) { … }
p:between(4,6) { … }
Browser Support
Currently, support for both CSS pseudo-selectors and flexbox28 is great in modern browsers. If your project targets users on IE 10 and above, you can use quantity queries and flexbox ordering together.
Where to Use It
When building websites, we often use programming languages that allow us to count and modify our content as needed. However, as CSS has improved, we’ve moved away from programming languages into advanced CSS properties.
One example is CSS animations. What was previously possible only through Flash or JavaScript is now achievable with pure CSS, a language for defining the presentation of our content.
Quantity ordering enables us to remove modified loops that count and insert content accordingly, allowing our content to be read semantically.
A great example of the usefulness of quantity ordering would be a news website with advertising. In the markup, all articles are organized together, and the ads are placed at the end. In terms of accessibility, this allows for an uninterrupted flow of content. The ads can then be placed throughout the content, using quantity ordering only on a presentational layer.
See the Pen vOLGPg29 by Drew Minns (@drewminns30211714118) on CodePen31221815129.
While ordering can be used to change the presentational display of elements, for accessibility, it can damage the experience. Be aware of how content flows and how it will be read on accessibility devices.
Conclusion
Quantity queries and quantity ordering are advanced concepts and might be scary for beginners. However, as we move presentational styling away from programming languages and into CSS, we should use these tools more and more.
Even as many members of our industry explore content queries32, we can now use quantity queries to modify the order of content simply by counting.
Excerpt image: Markus Spiske33
(ds, ml, al)
Footnotes
- 1 http://ift.tt/1jcvUCj
- 2 http://ift.tt/1x57L4x
- 3 http://ift.tt/1wQzozR
- 4 http://ift.tt/1FnbmWd
- 5 http://ift.tt/nfnxZ5
- 6 http://ift.tt/1nt4eJC
- 7 ‘http://ift.tt/1KGO3W0’
- 8 'http://ift.tt/1IFzX8c’
- 9 'http://codepen.io’
- 10 'http://ift.tt/1KGO3Fn’
- 11 'http://ift.tt/1IFzX8c’
- 12 'http://codepen.io’
- 13 'http://ift.tt/1IFzUJC’
- 14 'http://ift.tt/1IFzX8c’
- 15 'http://codepen.io’
- 16 'http://ift.tt/1IFzUJE’
- 17 'http://ift.tt/1IFzX8c’
- 18 'http://codepen.io’
- 19 http://ift.tt/Nk0jQg
- 20 'http://ift.tt/1KGO3W8’
- 21 'http://ift.tt/1IFzX8c’
- 22 'http://codepen.io’
- 23 http://ift.tt/1UYQQAn
- 24 http://ift.tt/1B0Gtmn
- 25 http://ift.tt/1UYQQAr
- 26 http://ift.tt/1H5MIcn
- 27 http://ift.tt/1UYQTfp
- 28 http://ift.tt/pyeOHA
- 29 'http://ift.tt/1UYQTfq’
- 30 'http://ift.tt/1IFzX8c’
- 31 'http://codepen.io’
- 32 http://ift.tt/1pJiRez
- 33 http://ift.tt/1UYQTfx
The post Quantity Ordering With CSS appeared first on Smashing Magazine.
from Smashing Magazine http://ift.tt/1M3TWiG via http://ift.tt/1M61DFR
from Tumblr http://ift.tt/1eZVAVi