You see it in Yahoo, Google, Bing, and all over the web. As you type into a search feild a box appears before your eyes showing you suggestions based on what you are typing. This offers more than just ease of use for your visitors, it allows them to see other content related to their search that they may have been otherwise unaware of. There are many tutorials on this subject, many of which rely heavily on API’s or copyright protected files.
Developing an auto suggest form is rather simple, with the right methods you too can churn out a professional looking auto suggest form without the complicated mess that many others provide. Visitors are likely to return to your site (provided the content is valid) to use features like this because so many other sites are slow in developing this type of technology.
The concept is simple, we run a JavaScript function every time a user presses a key in a search box, we use Ajax to send and receive data to a php search function and return the results to our page.
Creating the Form
All we need for this example is a text input, you will need to add a submit or other control if you desire it. We will also need to create a DIV which will display our results. The text input will use the onkeypress event to trap the users input and pass it through to our functions.
Input Area Setup + CSS
Our text input calls the functions “search” which will take the input from the field and use some Ajax to return the results into our DIV “searchresults”. As with Ajax we need to set up our XMLHttpRequest which acts as the communicator between our webpage and whatever we link to it.
Ajax XMLHttpRequest
function createXMLHttpRequest() {
if (typeof XMLHttpRequest != 'undefined') {
return new XMLHttpRequest();
}
try {
return new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
return new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
return false;
}
// ]]></script>
Setting up the Search Function
So now that the form is created and we have our XML function set up for our Ajax request we can create our search function in JavaScript which will post the data from the form to our search php script.
JavaScript Search Function
function search(){
var userInput = 'search='+document.getElementById('search').value;
var xmlReq = createXMLHttpRequest();
xmlReq.open("POST","search.php", true);
xmlReq.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xmlReq.onreadystatechange = function() {
if(xmlReq.readyState == 4 && xmlReq.status == 200) {
document.getElementById('searchresults').innerHTML = xmlReq.responseText;
document.getElementById('searchresults').style.display = "block";
}
}
xmlReq.send(userInput);
}
// ]]></script>
The code above creates a new XMLHttpRequest object and sends the input from the text box to our search php file by posting the data. Once the function receives a response from the search php file it will display the results within the DIV searchresults on our page.
Let’s write a basic search php file, we will use the LIKE statement in our sql statement.
Creating search.php
$user = "username";
$pass = "password";
$database = "my_database";
$c = mysql_connect($host, $user, $pass) or die(mysql_error());
mysql_select_db($database, $c);
$search = $_POST[‘search’];
$result = mysql_query("Select * from images where NAME like ‘$search%’ LIMIT 5");
while($i = mysql_fetch_assoc($result)){
extract($i);
echo "<strong>Name: </strong>$NAME
<hr />"
;}
mysql_close($c);
?>
The php code above runs a query on a table called “images”, you will need to change this to match whatever table you want to run the query on. We also use a LIMIT of 5 because we do not want to load the users page with every result, especially if it is a large database. Once we get our result we simply echo them out and our “search()” function receives the result to update our page.
Currently there will be no interaction on the results that we echo out, you could easily modify them to include a link to the page where the result would be relevant.
Taking it Further
To make your auto suggest forms look and feel more professional it would be a good idea to add some nice styling to your results, you can even include images. Changing the DIV styles around so that if floats on top of the page will make it so that the results do not push content on your main page out of the way.
Error handling and requiring a minimum number of characters before the search function is run is also a good idea. There are many avenues you can take to improve this form and function, if you develop it further and want to show off what you have done with it then leave us a comment below.
![[del.icio.us]](http://scriptperfect.com/wp-content/plugins/bookmarkify/delicious.png)
![[Digg]](http://scriptperfect.com/wp-content/plugins/bookmarkify/digg.png)
![[dzone]](http://scriptperfect.com/wp-content/plugins/bookmarkify/dzone.png)
![[Facebook]](http://scriptperfect.com/wp-content/plugins/bookmarkify/facebook.png)
![[Furl]](http://scriptperfect.com/wp-content/plugins/bookmarkify/furl.png)
![[Google]](http://scriptperfect.com/wp-content/plugins/bookmarkify/google.png)
![[LinkedIn]](http://scriptperfect.com/wp-content/plugins/bookmarkify/linkedin.png)
![[MySpace]](http://scriptperfect.com/wp-content/plugins/bookmarkify/myspace.png)
![[Newsvine]](http://scriptperfect.com/wp-content/plugins/bookmarkify/newsvine.png)
![[Propeller]](http://scriptperfect.com/wp-content/plugins/bookmarkify/propeller.png)
![[Reddit]](http://scriptperfect.com/wp-content/plugins/bookmarkify/reddit.png)
![[Slashdot]](http://scriptperfect.com/wp-content/plugins/bookmarkify/slashdot.png)
![[Spurl]](http://scriptperfect.com/wp-content/plugins/bookmarkify/spurl.png)
![[StumbleUpon]](http://scriptperfect.com/wp-content/plugins/bookmarkify/stumbleupon.png)
![[Technorati]](http://scriptperfect.com/wp-content/plugins/bookmarkify/technorati.png)
![[Twitter]](http://scriptperfect.com/wp-content/plugins/bookmarkify/twitter.png)
![[Email]](http://scriptperfect.com/wp-content/plugins/bookmarkify/email.png)
where to buy Premier and Stitched Chelsea jerseys ??…
[...]we adivce go to this website to see more about Chelsea jerseys and others. [...]…
[...]the time to read or visit the content or sites we have linked to below the[...]……
[...]here are some links to sites that we link to because we think they are worth visiting[...]……
where to buy Premier and Stitched Detroit Red Wings jerseys ??…
[...]we adivce go to this website to see more about Detroit Red Wings jerseys and others. [...]…
Sites we Like……
[...] Every once in a while we choose blogs that we read. Listed below are the latest sites that we choose [...]……
Wow!…
A very fascinating post….
Cool sites…
[...]we came across a cool site that you might enjoy. Take a look if you want[...]……
Great information…
This can be fantastic. Tip looked at doing this please so we are shocked. We are most certainly fascinated by this kind of the issue. Individuals appreciate your very place, and worth your precious time in this. Please keep updating. They may be incred…
easily felt or experience by women. when…
a woman starts to have hot flushes or when she perspires heavily at night, it’s possible that she has low estrogen levels. such symptoms may not be very discomforting though. what can be worse is when she begins to encounter pain…
where to buy Premier and Stitched Pittsburgh Penguins jerseys ??…
[...]we adivce go to this website to see more about Pittsburgh Penguins jerseys and others. [...]…
Links…
[...]Sites of interest we have a link to[...]……
where to buy Premier and Stitched Minnesota Vikings jerseys ??…
[...]we adivce go to this website to see more about Minnesota Vikings jerseys and others. [...]…
Check this out…
[...] that is the end of this article. Here you’ll find some sites that we think you’ll appreciate, just click the links over[...]……
Sites we Like……
[...] Every once in a while we choose blogs that we read. Listed below are the latest sites that we choose [...]……
About thatarticle I read……
…check that out – we’re linking to……
Websites worth visiting…
[...]here are some links to sites that we link to because we think they are worth visiting[...]……
………..
I suppose for now i’m going to be satisfied with bookmarking and also including the RSS feed to be able to my personal Search engines accounts. We look ahead to fresh improvements and may share this specific site along with my own Facebook party….
Blogs ou should be reading…
[...]Here is a Great Blog You Might Find Interesting that we Encourage You[...]……
Links…
[...] just down the page, are numerous totally not related sites to ours, nevertheless, they’re definitely worth going over [...]…
Cool webpage…
[...] even while websites we backlink just below are noticeably not affiliated with ours, we really feel they’re actually worth a go over, and so have a look [...]…
Related Sites……
[...] I love to look around the web, routinely I’ll just go to Digg and browse and check stuff out there [...]…
Websites worth visiting…
[...]here are some links to sites that we link to because we think they are worth visiting[...]……
where to buy Premier and Stitched Minnesota Timberwolves jerseys ??…
[...]we adivce go to this website to see more about Minnesota Timberwolves jerseys and others. [...]…
Superb website…
[...]always a big fan of linking to bloggers that I love but don’t get a lot of link love from[...]……
Online Article……
[...]The information mentioned in the article are some of the best available [...]……
Read was interesting, stay in touch……
[...]please visit the sites we follow, especially this particular one, as it turns our to be our picks among the list of[...]……
Cool sites…
[...]we came across a cool site that you might enjoy. Take a look if you want[...]……
Online Article……
[...]The information mentioned in the article are some of the best available [...]……
MAST…
[...]So it is advisable to switch over to food that has a higher alkaline content instead of acidic content. Natural herbs can help alleviate heartburn[...]…
Deck Picture…
[...]check below, are some absolutely unrelated internet sites to ours, on the other hand, they are most trustworthy sources that we use[...]…
Milkshake…
[...]Weak naturally and will not do some of its work properly. Its main responsibility is to allow the food particles to move into the stomach and also[...]…
Insulated Concrete Forms…
[...]The info talked about in the article are a few of the very best accessible [...]…
For Sale Luxury Home…
[...]just beneath, are several entirely not connected internet sites to ours, having said that, they are surely really worth going over[...]…
Sources……
[...] Tend not to smoke a pipe or consume alcohol as they can additionally induce heartburn. The correct way on how to treat heartburn will be to lower the spice ingredients [...]…
Related……
[...]just beneath, are numerous totally not related sites to ours, however, they are surely worth going over[...]……
Recent Blogrolls……
[...] I noticed somebody speaking about this on Tumblr and so it correlated to [...]…
Gems form the internet…
[...]very few websites that happen to be detailed below, from our point of view are undoubtedly well worth checking out[...]……
Check this out…
[...] that is the end of this article. Here you’ll find some sites that we think you’ll appreciate, just click the links over[...]……
Great information…
This can be brilliant. Person watch site’s articles or blog posts therefore we are impressed. We are interested in this type of behaviors. Sole appreciate your old lay, and cost your precious time in this. Please keep control. These are substantially …
Great information…
This is certainly impressive. Two of us stare upon the about me content material so we are stunned. We are most certainly curious about this type of offers. At least one appreciate his memo, and amount the effort in this. Please keep enhancing. They ma…