欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

jquery 自动完成 autocomplets ajax 有大用

shiping1 的头像


见附件 autocomplete1.zip JQuery AJAX Autocomplete – Country Example

Autocomplete feature is used to provide auto suggestion for users while entering input. In this tutorial, we are going to suggest country names for the users based on the keyword they entered into the input field by using jQuery AJAX.

We have jQuery script to call AJAX request on key-up event. This request will read country names from database that starts with the keyword entered by the user.

jquery-autocomplete

View DemoDownload

Input Field with Autocomplete Feature

This HTML code contains text input field for auto suggesting country name to the user. On key-up from this input field the jQuery function is triggered.

<div class="frmSearch">
	<input type="text" id="search-box" placeholder="Country Name" />
	<div id="suggesstion-box"></div>
</div>

jQuery Autocomplete Script

This script sends user input to a PHP page via jQuery AJAX function. On success, the list of countries will be shown to the user. We can select country name for the input field from the auto-sugessted list.

// AJAX call for autocomplete 
$(document).ready(function(){
	$("#search-box").keyup(function(){
		$.ajax({
		type: "POST",
		url: "readCountry.php",
		data:'keyword='+$(this).val(),
		beforeSend: function(){
			$("#search-box").css("background","#FFF url(LoaderIcon.gif) no-repeat 165px");
		},
		success: function(data){
			$("#suggesstion-box").show();
			$("#suggesstion-box").html(data);
			$("#search-box").css("background","#FFF");
		}
		});
	});
});
//To select country name
function selectCountry(val) {
$("#search-box").val(val);
$("#suggesstion-box").hide();
}

Reading Country Names from Database using PHP

This PHP script fetches data from the country table and form HTML to be returned as auto suggesstion.

<?php
require_once("dbcontroller.php");
$db_handle = new DBController();
if(!empty($_POST["keyword"])) {
$query ="SELECT * FROM country WHERE country_name like '" . $_POST["keyword"] . "%' ORDER BY country_name LIMIT 0,6";
$result = $db_handle->runQuery($query);
if(!empty($result)) {
?>
<ul id="country-list">
<?php
foreach($result as $country) {
?>
<li onClick="selectCountry('<?php echo $country["country_name"]; ?>');"><?php echo $country["country_name"]; ?></li>
<?php } ?>
</ul>
<?php } } ?>

View DemoDownload

This jQuery tutorial was added on November 6, 2014.

来自 http://phppot.com/jquery/jquery-ajax-autocomplete-country-example/

 

Ajax AutoComplete for jQuery

Ajax Autocomplete for jQuery allows you to easily create autocomplete/autosuggest boxes for text input fields.

Has no dependencies other than jQuery.

The standard jquery.autocomplete.js file is around 2.7KB when minified via Closure Compiler and gzipped.

API

  • $(selector).autocomplete(options);
    • Sets up autocomplete for input field(s).
    • options: An object literal which defines the settings to use for the autocomplete plugin.
      • serviceUrl: Server side URL or callback function that returns serviceUrl string. Optional if local lookup data is provided.
      • ajaxSettings: Any additional Ajax Settings that configure the jQuery Ajax request.
      • lookup: Lookup array for the suggestions. It may be array of strings or suggestionobject literals.
        • suggestion: An object literal with the following format: { value: 'string', data: any }.
      • lookupFilterfunction (suggestion, query, queryLowerCase) {} filter function for local lookups. By default it does partial string match (case insensitive).
      • lookupLimit: Number of maximum results to display for local lookup. Default: no limit.
      • onSelectfunction (suggestion) {} Callback function invoked when user selects suggestion from the list. this inside callback refers to input HtmlElement.
      • minChars: Minimum number of characters required to trigger autosuggest. Default: 1.
      • maxHeight: Maximum height of the suggestions container in pixels. Default: 300.
      • deferRequestBy: Number of miliseconds to defer ajax request. Default: 0.
      • width: Suggestions container width in pixels, e.g.: 300. Default: auto, takes input field width.
      • params: Additional parameters to pass with the request, optional.
      • formatResultfunction (suggestion, currentValue) {} custom function to format suggestion entry inside suggestions container, optional.
      • delimiter: String or RegExp, that splits input value and takes last part to as query for suggestions. Useful when for example you need to fill list of coma separated values.
      • zIndex: 'z-index' for suggestions container. Default: 9999.
      • type: Ajax request type to get suggestions. Default: GET.
      • noCache: Boolean value indicating whether to cache suggestion results. Defaultfalse.
      • onSearchStartfunction (query) {} called before ajax request. this is bound to input element.
      • onSearchCompletefunction (query, suggestions) {} called after ajax response is processed. this is bound to input element. suggestions is an array containing the results.
      • onSearchErrorfunction (query, jqXHR, textStatus, errorThrown) {} called if ajax request fails. this is bound to input element.
      • onInvalidateSelectionfunction () {} called when input is altered after selection has been made. this is bound to input element.
      • triggerSelectOnValidInput: Boolean value indicating if select should be triggered if it matches suggestion. Default true.
      • preventBadQueries: Boolean value indicating if it shoud prevent future ajax requests for queries with the same root if no results were returned. E.g. if Jam returns no suggestions, it will not fire for any future query that starts with Jam. Default true.
      • beforeRenderfunction (container) {} called before displaying the suggestions. You may manipulate suggestions DOM before it is displayed.
      • tabDisabled: Default false. Set to true to leave the cursor in the input field after the user tabs to select a suggestion.
      • paramName: Default query. The name of the request parameter that contains the query.
      • transformResultfunction(response, originalQuery) {} called after the result of the query is ready. Converts the result into response.suggestions format.
      • autoSelectFirst: if set to true, first item will be selected when showing suggestions. Default value false.
      • appendTo: container where suggestions will be appended. Default valuedocument.body. Can be jQuery object, selector or html element. Make sure to setposition: absolute or position: relative for that element.
      • dataType: type of data returned from server. Either 'text' (default) or 'jsonp', which will cause the autocomplete to use jsonp. You may return a json object in your callback when using jsonp.
      • showNoSuggestionNotice: Default false. When no matching results, display a notification label.
      • noSuggestionNotice: Default No results. Text or htmlString or Element or jQuery object for no matching results label.
      • forceFixPosition: Default: false. Suggestions are automatically positioned when their container is appended to body (look at appendTo option), in other cases suggestions are rendered but no positioning is applied. Set this option to force auto positioning in other cases.
      • orientation: Default bottom. Vertical orientation of the displayed suggestions, available values are autotopbottom. If set to auto, the suggestions will be orientated it the way that place them closer to middle of the view port.
      • groupBy: property name of the suggestion data object, by which results should be grouped.

 

Autocomplete instance has following methods:

  • setOptions(options): you may update any option at any time. Options are listed above.
  • clear: clears suggestion cache and current suggestions suggestions.
  • clearCache: clears suggestion cache.
  • disable: deactivate autocomplete.
  • enable: activates autocomplete if it was deactivated before.
  • hide: hides suggestions.
  • dispose: destroys autocomplete instance. All events are detached and suggestion containers removed.

 

There are two ways that you can invoke Autocomplete method. One is calling autocomplete on jQuery object and passing method name as string literal. If method has arguments, arguments are passed as consecutive parameters:

$('#autocomplete').autocomplete('disable');
$('#autocomplete').autocomplete('setOptions', options);

Or you can get Autocomplete instance by calling autcomplete on jQuery object without any parameters and then invoke desired method.

$('#autocomplete').autocomplete().disable();
$('#autocomplete').autocomplete().setOptions(options);

Usage

Html:

<input type="text" name="country" id="autocomplete"/>

Ajax lookup:

$('#autocomplete').autocomplete({
    serviceUrl: '/autocomplete/countries',
    onSelect: function (suggestion) {
        alert('You selected: ' + suggestion.value + ', ' + suggestion.data);
    }
});

Local lookup (no ajax):

var countries = [
   { value: 'Andorra', data: 'AD' },
   // ...
   { value: 'Zimbabwe', data: 'ZZ' }
];

$('#autocomplete').autocomplete({
    lookup: countries,
    onSelect: function (suggestion) {
        alert('You selected: ' + suggestion.value + ', ' + suggestion.data);
    }
});

Styling

Generated HTML markup for suggestions is displayed bellow. You may style it any way you'd like.

<div class="autocomplete-suggestions">
    <div class="autocomplete-group"><strong>NHL</strong></div>
    <div class="autocomplete-suggestion autocomplete-selected">...</div>
    <div class="autocomplete-suggestion">...</div>
    <div class="autocomplete-suggestion">...</div>
</div>

Style sample:

.autocomplete-suggestions { border: 1px solid #999; background: #FFF; overflow: auto; }
.autocomplete-suggestion { padding: 2px 5px; white-space: nowrap; overflow: hidden; }
.autocomplete-selected { background: #F0F0F0; }
.autocomplete-suggestions strong { font-weight: normal; color: #3399FF; }
.autocomplete-group { padding: 2px 5px; }
.autocomplete-group strong { display: block; border-bottom: 1px solid #000; }

Response Format

Response from the server must be JSON formatted following JavaScript object:

{
    // Query is not required as of version 1.2.5
    "query": "Unit",
    "suggestions": [
        { "value": "United Arab Emirates", "data": "AE" },
        { "value": "United Kingdom",       "data": "UK" },
        { "value": "United States",        "data": "US" }
    ]
}

Data can be any value or object. Data object is passed to formatResults function and onSelect callback. Alternatively, if there is no data you can supply just a string array for suggestions:

{
    "query": "Unit",
    "suggestions": ["United Arab Emirates", "United Kingdom", "United States"]
}

Non standard query/results

If your ajax service expects the query in a different format, and returns data in a different format than the standard response, you can supply the "paramName" and "transformResult" options:

$('#autocomplete').autocomplete({
    paramName: 'searchString',
    transformResult: function(response) {
        return {
            suggestions: $.map(response.myData, function(dataItem) {
                return { value: dataItem.valueField, data: dataItem.dataField };
            })
        };
    }
})

Grouping Results

Specify groupBy option of you data property if you wish results to be displayed in groups. For example, set groupBy: 'category' if your suggestion data format is:

[
    { value: 'Chicago Blackhawks', data: { category: 'NHL' } },
    { value: 'Chicago Bulls', data: { category: 'NBA' } }
]

Results will be formatted into two groups NHL and NBA.

Known Issues

If you use it with jQuery UI library it also has plugin named autocomplete. In this case you can use plugin alias devbridgeAutocomplete:

$('.autocomplete').devbridgeAutocomplete({ ... });

License

Ajax Autocomplete for jQuery is freely distributable under the terms of an MIT-stylelicense.

Copyright notice and permission notice shall be included in all copies or substantial portions of the Software.

Authors

Tomas Kirda / @tkirda

来自 https://www.devbridge.com/sourcery/components/jquery-autocomplete/

附件大小
Package icon autocomplete1.zip7.35 KB
普通分类: