HTML

Optimizing CSS selectors for load time; #home is faster than #menu li a#home

I was trying to figure out how to cut rendering time with smarter CSS. In my quest, I came across a plugin by google for Firebug called Page Speed which not only answered my question in the ‘Use efficient CSS selectors’ section (* #header #menu a:hover — Tag key with 2 descendant selectors and hover pseudo selector) but provided more details on the subject on the Page Speed Documentation.

“Descendant selectors are inefficient because, for each element that matches the key, the browser must also traverse up the DOM tree, evaluating every ancestor element until it finds a match or reaches the root element. The less specific the key, the greater the number of nodes that need to be evaluated.”

So, #home is faster than #menu li a#home; at least in Mozilla’s case. More on this here

Creating a simple news script that reads from an XML file

I recently recoded a website for a friend because his markup was pretty ugly (thanks to WYSIWYG editors). While I was doing that, he mentioned he’d like to have an xml file he could edit to update his news. Simple enough I said and banged out the following which includes a little helpful function that wraps paragraphs in HTML p tags. My friend alpha helped me rewrite some ugly regex with a novel idea:

print join '', map {qq[

$_

]} split (/\r?\n/,$object->content)

Of course, he’s a big perl coder so I had to create a php equivalent, nls2p.

Edit: Mookow mentioned he wanted to write links, so obviously a system would have to be put in place to support this. Using HTML tags in XML gets a little sloppy so I opted to use bbcode which is a very popular method to format text in web applications and very simple to add more filters.

The news post creator:

<?php

if (file_exists('news.xml')) {
    $xml = simplexml_load_file('news.xml');
	foreach ($xml->post as $post) {
	   echo "
<h4>".$post->title." - ".$post->date."</h4>

\n";
	   echo "
<div>".bbcode(nls2p($post->content))."</div>

\n";
	   echo "

--".$post->author."

\n";
	}
} else {
    echo "

Failed to open news source

";
}

The functions for formatting:

// Wrap paragraphs with

 tags
function nls2p($str) {
	$split_str = preg_split('#[\t]+?[\r\n]{1}#',$str);
	foreach ($split_str as $line) {
		$new_str = $new_str."

".preg_replace("/[\t\n]/","",$line)."

\n";
	}
	return $new_str;
}

// Parse bbcode as HTML
function bbcode($string) {
	$search = array(
		'@\[(?i)b\](.*?)\[/(?i)b\]@si',
		'@\[(?i)i\](.*?)\[/(?i)i\]@si',
		'@\[(?i)u\](.*?)\[/(?i)u\]@si',
		'@\[(?i)img\](.*?)\[/(?i)img\]@si',
		'@\[(?i)url=(.*?)\](.*?)\[/(?i)url\]@si',
		'@\[(?i)code\](.*?)\[/(?i)code\]@si'
	);
	$replace = array(
		'<b>\\1</b>',
		'<i>\\1</i>',
		'<u>\\1</u>',
		'<img src="\\1">',
		'<a href="\\1" target="_blank">\\2</a>',
		'<code>\\1</code>'
	);
	return preg_replace($search , $replace, $string);
}
?>

The XML data file:

<?xml version='1.0' standalone='yes'?>
<news>
<post>

		<date>03-29-09</date>
		<author>Moo</author>
		<content>The site has been completely recoded by a friend of mine, -z- from NexuizNinjaz.com. He even added this fancy news script. Now, to update the news, I don't even have to touch index.php! Alright, I'm out for now.

		OMG A [b]NEW LINE[/b]!

		Now with [i]italics[/i] and [u]underlines[/u] and [url=http://www.nexuizninjaz.com]links[/url]

		[code]code blocks[/code]

		and images

		[img]http://www.xepic.net/pics/pic_091622001182920068.jpg[/img]
		</content>
	</post>
<post>

		<date>03-29-09</date>
		<author>Moo</author>
		<content>Yeah, I removed the stupid gray background, because after a while it got boring. I changed the "Random Shiznit" column into something that could be a bit more productive. Once all of the other sites are up, I'll update the main page with the latest news from those. This main news column will be for the more intriguing news. I also decided to add titles to the news articles...Duuhhhhhhh

		OMG A NEW LINE!

		and again, LOL!
		</content>
	</post>
<post>

		<date>03-25-09</date>
		<author>Moo</author>
		<content>I added a boring gray background to the main page, as you can see. The hover text-changing effect was removed because of its stupidity. A cool guy named Fabzor re-colored the header for me.</content>
	</post>
<post>

		<date>03-23-09</date>
		<author>Moo</author>
		<content>Website updated, not much. Cool hover effects were added, but we still don't have much color in the page. Hopefully, I can find a good background and get this show on the road.</content>
	</post>
<post>

		<date>03-22-09</date>
		<author>Moo</author>
		<content>Most of the links up top will not work for the time being, this site is just getting edited. Soon, we'll have a better webpage than this one, but for now, deal with this one!</content>
	</post>
</news>

That’s pretty much it verbatim, including mookow’s news ^_^. Hope this is helpful to someone.