Unfortunately, the WordPress theme I am using did not show any views for each post. While I already had an analytics account, I wanted to display the number of total unique views on my website.
I quickly found a plugin called the Post Views Counter by Dfactory. I installed it and configured it so I could use the shortcode it produced ([post-views]) in my theme. However, the shortcode was formatted and the output contained some HTML that I simply did not need.
To demonstrate, let me print out the shortcode in this post:
The output from above (if you view source) is:
1 |
<div class="post-views post-273 entry-meta"> <span class="post-views-count">0</span></div> |
Note: The 0 will obviously be different (to match the views this post has).
I intend to use PHP regexp to get rid of all of the html and leave only the view count so I can put it into my theme. However, I first need to print out the shortcode within <pre></pre> tags because I suspect there is some whitespace in it.
So I use the follow PHP code to test:
1 2 3 4 5 6 |
<?php //Get shortcode in variable $tmp = do_shortcode( '[post-views]'); echo "<pre>" . $tmp . "</pre>"; ?> |
Here we are using the WordPress function
do_shortcode to print out the content.
The results from inspecting the page source are:
1 2 3 4 5 |
<div class="post-views post-273 entry-meta"> <span class="post-views-count">0</span> </div> |
Great so we now know what the actual output looks like. Now we can write the simple regexp we are going to use. I recommend using a regexp tester such as this one (http://www.phpliveregex.com/) so you can test the pattern as you go.
I ended up using the following pattern:
1 |
/<div.*?>.*<span.*?>(\d*)<\/span>.*<\/div>/s |
I used the s flag so that newlines were also matched.
Finally, I performed a match to get the view count:
1 2 3 4 5 6 7 8 9 10 |
<?php //Get shortcode in variable $tmp = do_shortcode( '[post-views]'); //Remove junk leaving only number using regexp preg_match_all("/<div.*?>.*<span.*?>(\d*)<\/span>.*<\/div>/s", $tmp, $results); //Output view count echo $results[1][0]; ?> |
Chris
June 5, 2016 at 9:10 AM
Really thank you for this!But how can we have the icon with the post number?Thank you!
Mo Beigi
November 19, 2016 at 4:06 PM
Simply place the number in an element with a class or id and use CSS to style it. You could also use FontAwesome to add a nice icon next to the view count.
Developer vs. Average User: The Post Views Counter Arena - BloggInc.
November 30, 2017 at 7:55 AM
[…] like to read more about what the plugin can do then be sure to check out Mohammad Ghasembeigi's review. And if you want more information on how to get started with it, check out Post Views Counter's […]
Developer vs. Average User: The Post Views Counter Arena | World of WordPress
November 30, 2017 at 3:10 PM
[…] to read more about what the plugin can do then be sure to check out Mohammad Ghasembeigi’s review. And if you want more information on how to get started with it, check out Post Views […]