<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Illuminati Karate Blog &#187; Web Development</title>
	<atom:link href="http://illuminatikarate.com/blog/category/web-development/feed/" rel="self" type="application/rss+xml" />
	<link>http://illuminatikarate.com/blog</link>
	<description></description>
	<lastBuildDate>Wed, 31 Mar 2010 14:12:59 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Submitting a Contact Form via AJAX From Your Facebook Page</title>
		<link>http://illuminatikarate.com/blog/submitting-a-contact-form-via-ajax-from-your-facebook-page/</link>
		<comments>http://illuminatikarate.com/blog/submitting-a-contact-form-via-ajax-from-your-facebook-page/#comments</comments>
		<pubDate>Thu, 03 Dec 2009 03:57:08 +0000</pubDate>
		<dc:creator>George Huger</dc:creator>
				<category><![CDATA[Facebook]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[FBJS]]></category>
		<category><![CDATA[FBML]]></category>

		<guid isPermaLink="false">http://illuminatikarate.com/blog/?p=297</guid>
		<description><![CDATA[We recently created a contact submission form on a client&#8217;s Facebook page, and were not satisfied with the default user experience. For starters, the form opened a new window, and there was no way to redirect the user back to a confirmation message on the Facebook page. 
We decided to submit the form via AJAX [...]]]></description>
			<content:encoded><![CDATA[<p><img src="/blog/wp-content/themes/ikBlog/img/facebook-48x48.png" alt="Facebook" style="float:left;margin:6px 20px 6px 0px;display:inline" />We recently created a contact submission form on a client&#8217;s Facebook page, and were not satisfied with the default user experience. For starters, the form opened a new window, and there was no way to redirect the user back to a confirmation message on the Facebook page. </p>
<p>We decided to submit the form via AJAX instead, and show the confirmation message directly on the Facebook page. This way the user would not have to leave the Facebook page, resulting in a smoother user experience. We couldn&#8217;t find a good explanation of how to do this on Google, so after figuring it out I decided to go ahead and write it up. </p>
<p>The following example will show you how to submit a basic contact form using AJAX from within your Facebook page. All HTML and Javascript that follows should be pasted directly into the &#8220;Edit FBML&#8221; screen on Facebook.</p>
<p><span id="more-297"></span>Here&#8217;s the example form HTML we&#8217;ll use for the rest of this article. It&#8217;s just two text fields (name and email) and a submit button:</p>

<div class="wp_codebox"><table width="100%" ><tr id="p2974"><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
</pre></td><td class="code" id="p297code4"><pre class="html" style="font-family:monospace;">&lt;form action=&quot;http://mywebsite.com/form_submit.php&quot; method=&quot;post&quot;&gt;
     &lt;p&gt;
          &lt;label for=&quot;name&quot;&gt;Name:&lt;/label&gt;
          &lt;input type=&quot;text&quot; name=&quot;name&quot; id=&quot;name&quot; /&gt;
     &lt;/p&gt;
     &lt;p&gt;
          &lt;label for=&quot;email&quot;&gt;Email:&lt;/label&gt;
          &lt;input type=&quot;text&quot; name=&quot;email&quot; id=&quot;email&quot; /&gt;
     &lt;/p&gt;
     &lt;button type=&quot;submit&quot; onclick=&quot;return submitAjaxForm();&quot;&gt;Submit&lt;/button&gt;
     &lt;p id=&quot;ajaxMessage&quot;&gt;&lt;/p&gt;
&lt;/form&gt;</pre></td></tr></table></div>

<p>There&#8217;s three things you should take note of:</p>
<ol>
<li>The form&#8217;s <b>action</b> attribute is set to a page on mywebsite.com, not facebook.com (replace mywebsite.com with your own domain)</li>
<li>The submit button has an onSubmit event that calls a function submitAjaxForm, which we&#8217;ll define shortly</li>
<li>At the end of the form is an empty paragraph tag. We&#8217;ll use this space to display messages to the user.</li>
</ol>
<p>On our server, form_submit.php is a simple PHP script that logs the submissions, and sends back a message for the user letting them know the submission was successful. It might look something like this:</p>

<div class="wp_codebox"><table width="100%" ><tr id="p2975"><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code" id="p297code5"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
     log_submission<span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'name'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'email'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
     <a href="http://www.php.net/echo"><span style="color: #990000;">echo</span></a> <span style="color: #0000ff;">&quot;Thank you for your submission!&quot;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Of course, your script will be more sophisticated than this one, and doesn&#8217;t have to be written in PHP. Its on your server, so you can handle logging the submission however you like. Just make sure the output is valid <a href="http://wiki.developers.facebook.com/index.php/FBML">FBML</a>.</p>
<p>With the form HTML added to your Facebook page and the logging script in place, the only thing left is adding the Javascript to submit the form via AJAX and show the confirmation message.</p>
<p class="note"><b>Note:</b> Facebook does not allow you to use any Javascript function you like, for security purposes. Instead they&#8217;ve created a library of Javascript functions for accessing the DOM, AJAX, and event binding called <a href="http://wiki.developers.facebook.com/index.php/FBJS">FBJS</a>. These functions are used in the example below.</p>
<p>We&#8217;ll now define the submitAjaxForm() function we referenced earlier in our submit button&#8217;s onSubmit event:</p>

<div class="wp_codebox"><table width="100%" ><tr id="p2976"><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
</pre></td><td class="code" id="p297code6"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>script<span style="color: #339933;">&gt;&lt;!--</span>
<span style="color: #003366; font-weight: bold;">function</span> submitAjaxForm<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> 
<span style="color: #009900;">&#123;</span> 
	<span style="color: #006600; font-style: italic;">// declare a new FBJS AJAX object</span>
	<span style="color: #003366; font-weight: bold;">var</span> ajax <span style="color: #339933;">=</span> <span style="color: #003366; font-weight: bold;">new</span> Ajax<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> 
	ajax.<span style="color: #660066;">responseType</span> <span style="color: #339933;">=</span> Ajax.<span style="color: #660066;">FBML</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #006600; font-style: italic;">// define a callback to handle the response from the server</span>
	ajax.<span style="color: #660066;">ondone</span> <span style="color: #339933;">=</span> <span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span>data<span style="color: #009900;">&#41;</span> 
	<span style="color: #009900;">&#123;</span> 
		document.<span style="color: #660066;">getElementById</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'ajaxMessage'</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">setInnerFBML</span><span style="color: #009900;">&#40;</span>data<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span>
&nbsp;
	<span style="color: #006600; font-style: italic;">// let the user know we're sending the data	</span>
	document.<span style="color: #660066;">getElementById</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'ajaxMessage'</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">setInnerXHTML</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'Submitting your information, please wait...'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
	<span style="color: #006600; font-style: italic;">// collect field values</span>
	<span style="color: #003366; font-weight: bold;">var</span> queryParams <span style="color: #339933;">=</span> <span style="color: #009900;">&#123;</span> <span style="color: #3366CC;">'name'</span> <span style="color: #339933;">:</span> document.<span style="color: #660066;">getElementById</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'name'</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">getValue</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #3366CC;">'email'</span> <span style="color: #339933;">:</span> document.<span style="color: #660066;">getElementById</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'email'</span><span style="color: #009900;">&#41;</span>.<span style="color: #660066;">getValue</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#125;</span><span style="color: #339933;">;</span>
	ajax.<span style="color: #660066;">post</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'http://mywebsite.com/form_submit.php'</span><span style="color: #339933;">,</span> queryParams<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	<span style="color: #000066; font-weight: bold;">return</span> <span style="color: #003366; font-weight: bold;">false</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #006600; font-style: italic;">//--&gt;&lt;/script&gt;</span></pre></td></tr></table></div>

<p><em>Note: The opening and closing HTML comments embedded in the Javascript are important, so leave them intact.</em></p>
<p>The example is fairly self explanatory, but here&#8217;s what&#8217;s happening:</p>
<ol>
<li>Declare a new Ajax object, which is one of the FBJS classes. We then set its response type to FBML (Ajax.RAW and Ajax.JSON are also accepted).</li>
<li>Define a callback function to handle the response from the server. In this case, our function simply takes the response from the server and displays it in the #ajaxMessage paragraph we defined earlier.</li>
<li>Update the user to let them know their data is being submitted using FBJS&#8217;s setInnerFBML function.</li>
<li>Collect the form field&#8217;s values into an array named queryParams, using FBJS&#8217;s getElementById and getValue functions. Although getElementById is similar to the standard Javascript function, it accounts for the random slugs Facebook injects into div id&#8217;s for security (View Source on a Facebook page and look at the div ID&#8217;s to see this in action).</li>
<li>Send the AJAX request, using FBJS&#8217; Ajax.post function. The second argument is optional, and should be an array containing the query parameters.</li>
<li>&#8220;return false;&#8221; prevents the form&#8217;s normal submit behavior</li>
</ol>
<p>That&#8217;s all there is to it! If you have any questions or if I should clarify a section, let me know in the comments.</p>
]]></content:encoded>
			<wfw:commentRss>http://illuminatikarate.com/blog/submitting-a-contact-form-via-ajax-from-your-facebook-page/feed/</wfw:commentRss>
		<slash:comments>27</slash:comments>
		</item>
		<item>
		<title>Free Webservice to Geocode IP Addresses Saves The Day</title>
		<link>http://illuminatikarate.com/blog/free-webservice-to-geocode-ip-addresses-saves-the-day/</link>
		<comments>http://illuminatikarate.com/blog/free-webservice-to-geocode-ip-addresses-saves-the-day/#comments</comments>
		<pubDate>Sat, 23 May 2009 06:03:06 +0000</pubDate>
		<dc:creator>George Huger</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[Webservices]]></category>
		<category><![CDATA[geolocation]]></category>
		<category><![CDATA[JSON]]></category>
		<category><![CDATA[REST]]></category>

		<guid isPermaLink="false">http://illuminatikarate.com/blog/?p=265</guid>
		<description><![CDATA[At Illuminati Karate we love a challenge. So when our client called needing two lists of 1500 IP addresses geocoded as quickly as possible, we rose to the occasion. With the help of PHP and a freely available web service we were able to complete the task in just under an hour. Here&#8217;s how we [...]]]></description>
			<content:encoded><![CDATA[<p>At Illuminati Karate we love a challenge. So when our client called needing two lists of 1500 IP addresses geocoded as quickly as possible, we rose to the occasion. With the help of PHP and a freely available web service we were able to complete the task in just under an hour. Here&#8217;s how we did it.</p>
<p><span id="more-265"></span><br />
<h4>The Challenge</h4>
<p>Given 2 text files, each containing approximately 1500 anonymous IP addresses, we were to determine how many resolved to each US state. Separate counts were to be maintained for each list. The data was needed for a time sensitive report, and the clock was ticking.</p>
<h4>The Tools</h4>
<p>There are several freely available SQL databases which correlate IP addresses to their geographic location, such as <a href="http://www.iplocationtools.com/sql_database.php">this one</a> maintained by iplocationtools.com. If we&#8217;d been building a web app setting up a local instance would have made sense, but at 4.1 million rows it was going to take too long to get a local instance running.</p>
<p>What we needed was a web service to do the lookups for us. In the past, we&#8217;d been unable to find a free web service to fulfill this role, as most will not provide data beyond a country level. But today we were lucky, and Google quickly turned up the perfect solution: a free REST web service running the very same database from <a href="http://www.iplocationtools.com">iplocationtools.com</a>. Its exactly what it says on the tin: <a href="http://freegeoip.appspot.com/">a free IP geolocation webservice</a>. It gave us even more accuracy than we needed (cities and zipcodes!), and even better it was running on <a href="http://www.appspot.com" rel="nofollow">Google&#8217;s App Engine</a>, so we knew it could handle a heavy load.</p>
<p>With the primary problem solved, the only thing needed was a simple PHP script to read in the input files, query the web service for each IP, parse the JSON results, and maintain a total for each state.</p>
<h4>The Solution</h4>
<p>Thanks to PHP5&#8217;s excellent JSON support, the script to interact with the web service was trivial. I won&#8217;t bore you with the file I/O and tallying, but here&#8217;s the function which converts the IP address to its state.</p>

<div class="wp_codebox"><table width="100%" ><tr id="p2658"><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
</pre></td><td class="code" id="p265code8"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
	<span style="color: #000000; font-weight: bold;">function</span> getStateFromIp<span style="color: #009900;">&#40;</span><span style="color: #000088;">$ip</span><span style="color: #009900;">&#41;</span>
	<span style="color: #009900;">&#123;</span>
		<span style="color: #000088;">$resp</span> <span style="color: #339933;">=</span> json_decode<span style="color: #009900;">&#40;</span><a href="http://www.php.net/file_get_contents"><span style="color: #990000;">file_get_contents</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'http://freegeoip.appspot.com/json/'</span> <span style="color: #339933;">.</span> <a href="http://www.php.net/urlencode"><span style="color: #990000;">urlencode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$ip</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		<span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #000088;">$resp</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">status</span><span style="color: #009900;">&#41;</span>
		<span style="color: #009900;">&#123;</span>
			<span style="color: #666666; font-style: italic;">// lookup failed</span>
			<span style="color: #b1b100;">return</span> <span style="color: #000000; font-weight: bold;">false</span><span style="color: #339933;">;</span>
		<span style="color: #009900;">&#125;</span>
		<span style="color: #b1b100;">else</span>
		<span style="color: #009900;">&#123;</span>
			<span style="color: #b1b100;">return</span> <span style="color: #000088;">$resp</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">regioncode</span><span style="color: #339933;">;</span>		
		<span style="color: #009900;">&#125;</span>
	<span style="color: #009900;">&#125;</span>      
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Take note of the the <a href="http://php.net/json_decode">json_decode</a> function. If you&#8217;re not already familiar with it I&#8217;d highly recommend taking a few minutes to familiarize yourself with <a href="http://php.net/manual/en/ref.json.php">PHP5&#8217;s JSON functions</a>. JSON is becoming a de facto standard for web services, so being able to painlessly convert to and from JSON in PHP is critical.</p>
<p>Finally, we simply used <a href="http://php.net/manual/en/function.print-r.php">print_r</a> to dump the array containing the per state totals, and used <a href="http://www.datawatch.com/_products/monarch_pro.php">Monarch</a> to pull the data into an Excel file which we then delivered to the customer. (<em>Note: under normal circumstances we would have reached a more elegant solution, but given the time constraints brute force was the name of the game.</em>)</p>
<h4>Conclusion</h4>
<p><a href="http://illuminatikarate.com/web-services/">On-demand web services</a> are fundamentally changing the way we interact with data. Projects which were formerly large, slow, and expensive can now be completed in a matter of hours or days for a fraction of the cost. Perhaps most importantly, anyone can get involved.</p>
<p>Its an exciting time, and we&#8217;re happy to be a part of it all. Thanks for reading!</p>
<p class="note"><em>If your company needs help with a custom dataset <a href="http://illuminatikarate.com/contact-us/" rel="nofollow">contact us</a> today. Even if you&#8217;re not sure exactly what to ask for, we can help fill in the blanks.</em></p>
]]></content:encoded>
			<wfw:commentRss>http://illuminatikarate.com/blog/free-webservice-to-geocode-ip-addresses-saves-the-day/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>10 Javascript Tricks for Better Forms</title>
		<link>http://illuminatikarate.com/blog/10-javascript-tricks-for-better-forms/</link>
		<comments>http://illuminatikarate.com/blog/10-javascript-tricks-for-better-forms/#comments</comments>
		<pubDate>Thu, 05 Mar 2009 17:53:56 +0000</pubDate>
		<dc:creator>George Huger</dc:creator>
				<category><![CDATA[Javascript]]></category>
		<category><![CDATA[Web Development]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[combo box]]></category>
		<category><![CDATA[forms]]></category>
		<category><![CDATA[progress bars]]></category>

		<guid isPermaLink="false">http://illuminatikarate.com/blog/?p=4</guid>
		<description><![CDATA[Nothing exposes the gap between web apps and desktop applications more than plain HTML forms. Fortunately, by leveraging Javascript we can start to close this gap while maintaining a consistent experience for users using screen readers and old browsers.
We&#8217;ve identified 10 ways in which normal HTML forms fall short, and dug up the Javascript and [...]]]></description>
			<content:encoded><![CDATA[<p>Nothing exposes the gap between web apps and desktop applications more than plain HTML forms. Fortunately, by leveraging Javascript we can start to close this gap while maintaining a consistent experience for users using screen readers and old browsers.</p>
<p>We&#8217;ve identified 10 ways in which normal HTML forms fall short, and dug up the Javascript and CSS code you&#8217;ll need to fix them. Although the best enhancements are so intuitive as to be unnoticed, rest assured your visitors would thank you if they knew.</p>
<p class="note"><em>Note: Many of the solutions in this list depend on <a href="http://jquery.com">jQuery</a>, our javascript framework of choice.</em></p>
<p><span id="more-4"></span></p>
<h4>Combo Boxes</h4>
<p>For those unfamiliar, a Combo Box is a combination of a text box and a list box. It allows the user the option of selecting from a list of predefined items, or entering a new item of their choice. Your browser&#8217;s address bar is a perfect example.</p>
<p>Its an elegant solution to a common problem, yet the combo box was somehow left out of HTML&#8217;s form elements.</p>
<p>Enter <strong><a href="http://code.google.com/p/sexy-combo/">Sexy Combo</a></strong>, a jQuery plugin which provides a seamless solution. Users without javascript will simply encounter a normal select element.</p>
<h4>Progress Bars For Uploads</h4>
<p>The standard file input frustrates users with its awkwardness and lack of information. Furthermore, not being able to upload asynchronously results in a lot of wasted time.</p>
<p>To be fair, providing information on an ongoing upload is trickier than it might sound. Thankfully, <strong><a href="http://swfupload.org">SWFUpload</a></strong> provides a very clean solution that will convert your standard file inputs into a very flexible and asynchronous file uploader complete with a progress bar.</p>
<p class="note"><em>Note: As the name implies, SWFUpload uses an invisible Flash movie to actually perform the upload. As such, your users will need Flash as well as javascript enabled to take advantage.</em></p>
<h4>Date Selection</h4>
<p>Using a standard text input for a date leads to all manner of formatting issues, and using 3 select boxes is cumbersome. Desktop apps have a great solution &#8211; the date picker, which is to say a pop-up calendar.</p>
<p><a href="http://ui.jquery.com/demos/datepicker"><strong>jQuery UI&#8217;s Datepicker plugin</strong></a> is a perfect solution.</p>
<p class="note"><em>Note: The download page is for the entire jQuery UI library, but will allow you to download only what you want. I&#8217;d recommend only downloading the Datepicker with Packed compression, as the library is quite large.</em></p>
<h4>Time Selection</h4>
<p>Time selection in a normal HTML form has the same problems as date selection, but it lacks a uniform solution. We&#8217;ve provided 2 implementations, so that you can decide which is more appropriate for your audience.</p>
<p><strong><a href="http://keith-wood.name/timeEntry.html">Time Entry</a></strong> is a jQuery plugin that is simple and very customizable. Its normal behavior is to provide a text box where the user can use the arrow keys to quickly set the hour, minute, and am/pm settings. Its similar to how you set the time in Windows, so it should be intuitive for most visitors.</p>
<p><a href="http://www.oakcitygraphics.com/jquery/clockpick/trunk/ClockPick.cfm"><strong>ClockPick</strong></a> is a more creative, but less traditional solution. If you&#8217;re generally comfortable with creative inputs, its a fantastic interface.</p>
<h4>Color Selection</h4>
<p>Color selection might not apply to every app, but when you need it the native options leave you out in the cold. There&#8217;s only a handful of visitors who would know what a hex code is, and even fewer who have their favorites memorized.</p>
<p><a href="http://www.eyecon.ro/colorpicker/"><strong>ColorPicker</strong></a> is a very nice solution, which provides a color picker similar to that in Adobe Photoshop.</p>
<h4>Input Masking / Validation</h4>
<p>Input masking is when a text box has static characters already included, and the cursor moves intelligently. For example, a text box for a social security number should already have the dashes, and after you enter the first three numbers the cursor should move past the first dash. Furthermore, it shouldn&#8217;t allow anything but numbers to be entered.</p>
<p>Input validation is checking to see if the value the user entered falls within the boundaries. In our social security number example, if the number entered isn&#8217;t exactly 9 digits, its not valid.</p>
<p class="note"><em>Note: Client-side validation can be easily overridden by a malicious visitor, so you&#8217;ll need to sanitize and validate your data server-side as well.</em></p>
<p>The <strong><a href="http://digitalbush.com/projects/masked-input-plugin/">Masked Input jQuery plugin</a></strong> can implement both of these features for us. It will let you define any custom mask, and you can use its &#8220;completed&#8221; callback function to flag the inputs as valid.</p>
<h4>Better Support for Defaults</h4>
<p>HTML inputs do allow for default values, but its nice to have them disappear when the input gains focus, and reappear on blur if the user hasn&#8217;t entered anything.</p>
<p>The aptly named <strong><a href="http://plugins.jquery.com/project/defaultvalue">Default Values plugin</a></strong> does exactly that.</p>
<h4>AJAX Form Submission</h4>
<p>Submitting forms can be a great use of AJAX, particularly if you have a series of forms which are affected by the user entered values (i.e. a wizard). Its also a nice way to break a long form into stages to decrease abandonment.</p>
<p>The <strong><a href="http://malsup.com/jquery/form/">jQuery Form Plugin</a></strong> is an easy way to convert your current forms to AJAX forms while preserving their functionality for users without Javascript. If you are feeling creative or want to write something more customized, <strong><a href="http://docs.jquery.com/Ajax/serialize">jQuery&#8217;s serialize function</a></strong> will get you almost all the way there.</p>
<h4>Automatically Growing Textareas</h4>
<p>If you&#8217;ve used <a href="http://facebook.com">Facebook</a> or <a href="http://basecamphq.com">Basecamp</a>, you&#8217;ve probably noticed that the textareas get longer when you&#8217;re running out of space. Its aesthetically pleasing and very convenient.</p>
<p>Here&#8217;s a <a href="http://plugins.jquery.com/project/autogrow"><strong>jQuery plugin</strong></a> to add the same behavior to your textareas.</p>
<h4>Spin Buttons</h4>
<p>A spin button is a text box with up/down arrows, allowing the user to easily &#8220;nudge&#8221; a numeric value up or down. Like a combo box, the user can still type in their own value.</p>
<p>They are most useful when the range of possible values is fairly small &#8211; for example selecting the number of diners in a reservation.</p>
<p>The <strong><a href="http://code.google.com/p/jquery-spin-button/">jQuery Spin Button</a></strong> plugin is a nice implementation of this control.</p>
<h4>One More Thing</h4>
<p>Each of these ten solutions requires at least one external javascript library, and some require stylesheets. Implementing all ten would be great, but including a bunch of external javascript / css files can drastically increase the load time of your page.</p>
<p>Therefore, we recommend you do 2 things:</p>
<ol>
<li>Concatenate your Javascript and CSS files as much as makes sense.</li>
<li>Compress them using Dean Edward&#8217;s <a href="http://dean.edwards.name/packer/">packer</a> and <a href="http://www.cssdrive.com/index.php/main/csscompressor/">CSSDrive&#8217;s CSS Compressor</a>, respectively.</li>
</ol>
<p>Also, if you know of any scripts that we missed here let us know in the comments. Thanks for reading!</p>
]]></content:encoded>
			<wfw:commentRss>http://illuminatikarate.com/blog/10-javascript-tricks-for-better-forms/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>
