我是靠谱客的博主 朴素短靴,这篇文章主要介绍使用PHP,jQuery,MySQL和XML自动完成,现在分享给大家,希望可以做个参考。

autocomplete with php, jquery, mysql and xml
autocomplete with php, jquery, mysql and xml

Autocomplete with PHP, jQuery, MySQL and XML. Today I have new article for PHP. I will tell you about implementation autocomplete for your sites. Data can be located in different sources – directly in the JS code, in the database, and even in the XML file.

使用PHP,jQuery,MySQL和XML自动完成。 今天,我有关于PHP的新文章。 我将告诉您有关您网站的实现自动完成功能。 数据可以位于不同的源中-直接在JS代码,数据库中,甚至在XML文件中。

现场演示

[sociallocker]

[社交储物柜]

打包下载

[/sociallocker]

[/ sociallocker]

Now – download the source files and lets start coding !

现在–下载源文件并开始编码!

步骤1. HTML (Step 1. HTML)

Here are HTML layout for our autocomplete example page:

这是我们自动完成示例页面HTML布局:

index.html (index.html)

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<!DOCTYPE html> <html lang="en" > <head> <meta charset="utf-8" /> <title>Autocomplete with PHP, jQuery, MySQL and XML | Script Tutorials</title> <link href="css/jquery.autocomplete.css" rel="stylesheet" type="text/css" /> <link href="css/main.css" rel="stylesheet" type="text/css" /> <script type="text/javascript" src="js/jquery-1.5.2.min.js"></script> <script type="text/javascript" src="js/jquery.autocomplete.pack.js"></script> <script type="text/javascript" src="js/script.js"></script> </head> <body> <div class="container"> <form action="#"> <p><label>Your month:</label> <input id="month" type="text" autocomplete="off"></p> <p><label>Your year:</label> <input id="year" type="text" autocomplete="off"></p> <p><label>Your country:</label> <input id="country" type="text" autocomplete="off"></p> </form> </div> <footer> <h2>Autocomplete with PHP, jQuery, MySQL and XML</h2> <a href="https://www.script-tutorials.com/autocomplete-with-php-jquery-mysql-and-xml/" class="stuts">Back to original tutorial on <span>Script Tutorials</span></a> </footer> </body> </html>
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<!DOCTYPE html> <html lang="en" > <head> <meta charset="utf-8" /> <title>Autocomplete with PHP, jQuery, MySQL and XML | Script Tutorials</title> <link href="css/jquery.autocomplete.css" rel="stylesheet" type="text/css" /> <link href="css/main.css" rel="stylesheet" type="text/css" /> <script type="text/javascript" src="js/jquery-1.5.2.min.js"></script> <script type="text/javascript" src="js/jquery.autocomplete.pack.js"></script> <script type="text/javascript" src="js/script.js"></script> </head> <body> <div class="container"> <form action="#"> <p><label>Your month:</label> <input id="month" type="text" autocomplete="off"></p> <p><label>Your year:</label> <input id="year" type="text" autocomplete="off"></p> <p><label>Your country:</label> <input id="country" type="text" autocomplete="off"></p> </form> </div> <footer> <h2>Autocomplete with PHP, jQuery, MySQL and XML</h2> <a href="https://www.script-tutorials.com/autocomplete-with-php-jquery-mysql-and-xml/" class="stuts">Back to original tutorial on <span>Script Tutorials</span></a> </footer> </body> </html>

步骤2. CSS (Step 2. CSS)

Now, lets define all used styles:

现在,让我们定义所有使用的样式:

css / main.css (css/main.css)

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
*{ margin:0; padding:0; } body { background-repeat:no-repeat; background-color:#bababa; background-image: -webkit-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: -moz-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: -o-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: radial-gradient(600px 200px, circle, #eee, #bababa 40%); color:#fff; font:14px/1.3 Arial,sans-serif; min-height:600px; } footer { background-color:#212121; bottom:0; box-shadow: 0 -1px 2px #111111; display:block; height:70px; left:0; position:fixed; width:100%; z-index:100; } footer h2{ font-size:22px; font-weight:normal; left:50%; margin-left:-400px; padding:22px 0; position:absolute; width:540px; } footer a.stuts,a.stuts:visited{ border:none; text-decoration:none; color:#fcfcfc; font-size:14px; left:50%; line-height:31px; margin:23px 0 0 110px; position:absolute; top:0; } footer .stuts span { font-size:22px; font-weight:bold; margin-left:5px; } .container { border:3px #111 solid; color:#000; margin:20px auto; padding:20px; position:relative; text-align:center; width:300px; border-radius:15px; -moz-border-radius:15px; -webkit-border-radius:15px; } .ac_results { border: solid 1px #E5E5E5; color:#000; border-radius:0 0 5px 5px; -moz-border-radius:0 0 5px 5px; -webkit-border-radius:0 0 5px 5px; } .ac_over { background-color:#444; } form p { margin-bottom:5px; text-align:right; } form input { background-color: #FFFFFF; background: -moz-linear-gradient(top, #FFFFFF, #EEEEEE 1px, #FFFFFF 25px); background: -webkit-gradient(linear, left top, left 25, from(#FFFFFF), color-stop(4%, #EEEEEE), to(#FFFFFF)); border: solid 1px #E5E5E5; font-size:14px; outline: 0; padding: 9px; width: 180px; border-radius:5px; -moz-border-radius:5px; -webkit-border-radius:5px; box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; -moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; -webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; } form input:hover, form input:focus { border-color: #C9C9C9; box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; -moz-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; -webkit-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; }
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
*{ margin:0; padding:0; } body { background-repeat:no-repeat; background-color:#bababa; background-image: -webkit-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: -moz-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: -o-radial-gradient(600px 200px, circle, #eee, #bababa 40%); background-image: radial-gradient(600px 200px, circle, #eee, #bababa 40%); color:#fff; font:14px/1.3 Arial,sans-serif; min-height:600px; } footer { background-color:#212121; bottom:0; box-shadow: 0 -1px 2px #111111; display:block; height:70px; left:0; position:fixed; width:100%; z-index:100; } footer h2{ font-size:22px; font-weight:normal; left:50%; margin-left:-400px; padding:22px 0; position:absolute; width:540px; } footer a.stuts,a.stuts:visited{ border:none; text-decoration:none; color:#fcfcfc; font-size:14px; left:50%; line-height:31px; margin:23px 0 0 110px; position:absolute; top:0; } footer .stuts span { font-size:22px; font-weight:bold; margin-left:5px; } .container { border:3px #111 solid; color:#000; margin:20px auto; padding:20px; position:relative; text-align:center; width:300px; border-radius:15px; -moz-border-radius:15px; -webkit-border-radius:15px; } .ac_results { border: solid 1px #E5E5E5; color:#000; border-radius:0 0 5px 5px; -moz-border-radius:0 0 5px 5px; -webkit-border-radius:0 0 5px 5px; } .ac_over { background-color:#444; } form p { margin-bottom:5px; text-align:right; } form input { background-color: #FFFFFF; background: -moz-linear-gradient(top, #FFFFFF, #EEEEEE 1px, #FFFFFF 25px); background: -webkit-gradient(linear, left top, left 25, from(#FFFFFF), color-stop(4%, #EEEEEE), to(#FFFFFF)); border: solid 1px #E5E5E5; font-size:14px; outline: 0; padding: 9px; width: 180px; border-radius:5px; -moz-border-radius:5px; -webkit-border-radius:5px; box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; -moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; -webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 8px; } form input:hover, form input:focus { border-color: #C9C9C9; box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; -moz-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; -webkit-box-shadow: rgba(0,0,0, 0.5) 0px 0px 8px; }

In our package you can find few more files:

在我们的软件包中,您可以找到更多文件:

css / jquery.autocomplete.css + css / indicator.gif (css/jquery.autocomplete.css + css/indicator.gif)

Both files I got from autocomplete jquery package (this is default files – don`t need to re-publish it in our article)

我从自动完成jquery包中获得的两个文件(这是默认文件,不需要在我们的文章中重新发布)

步骤3. Javascript (Step 3. Javascript)

Its time to prepare JS:

是时候准备JS了:

js / script.js (js/script.js)

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$(function(){ $('#month').autocomplete(['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'], { width: 200, max: 3 }); $('#year').autocomplete('data.php?mode=xml', { width: 200, max: 5 }); $('#country').autocomplete('data.php?mode=sql', { width: 200, max: 5 }); });
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$(function(){ $('#month').autocomplete(['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'], { width: 200, max: 3 }); $('#year').autocomplete('data.php?mode=xml', { width: 200, max: 5 }); $('#country').autocomplete('data.php?mode=sql', { width: 200, max: 5 }); });

As you can see – very easy syntax of using Autocomplete. In first case I hardcoded possible values directly in JS code. Second and third cases – through PHP file (using different way of obtaining data – XML and SQL). In package you can find two another JS files:

如您所见–使用自动完成功能非常简单的语法。 在第一种情况下,我直接在JS代码中对可能的值进行了硬编码。 第二种和第三种情况–通过PHP文件(使用不同的数据获取方式– XML和SQL)。 在软件包中,您可以找到另外两个JS文件:

js / jquery-1.5.2.min.js + js / jquery.autocomplete.pack.js (js/jquery-1.5.2.min.js + js/jquery.autocomplete.pack.js)

This is jQuery library itself plus Autocomplete plugin

这是jQuery库本身加上Autocomplete插件

步骤4. SQL (Step 4. SQL)

Now, lets prepare our database – lets add 1 new table:

现在,让我们准备数据库–让我们添加1个新表:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE `s85_countries` ( `country_code` varchar(2) NOT NULL, `country_name` varchar(255) NOT NULL, PRIMARY KEY (`country_code`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; INSERT INTO `s85_countries` (`country_code`, `country_name`) VALUES ('AR', 'Argentina'), ('AU', 'Australia'), ('BR', 'Brazil'), ('CA', 'Canada'), ('CN', 'China'), ('IN', 'India'), ('KZ', 'Kazakhstan'), ('RU', 'Russia'), ('SD', 'Sudan'), ('US', 'United States');
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE `s85_countries` ( `country_code` varchar(2) NOT NULL, `country_name` varchar(255) NOT NULL, PRIMARY KEY (`country_code`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; INSERT INTO `s85_countries` (`country_code`, `country_name`) VALUES ('AR', 'Argentina'), ('AU', 'Australia'), ('BR', 'Brazil'), ('CA', 'Canada'), ('CN', 'China'), ('IN', 'India'), ('KZ', 'Kazakhstan'), ('RU', 'Russia'), ('SD', 'Sudan'), ('US', 'United States');

This small table contain several records – list of countries. I took that SQL code from one of our old tutorials.

这个小表包含一些记录-国家列表。 我从其中一本旧教程中获取了该SQL代码。

步骤5. PHP (Step 5. PHP)

This step most important – now you will see how we returning data for Autocomplete:

这一步最重要–现在,您将看到我们如何返回自动完成数据:

data.php (data.php)

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?php if (version_compare(phpversion(), "5.3.0", ">=") == 1) error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED); else error_reporting(E_ALL & ~E_NOTICE); require_once('classes/CMySQL.php'); $sParam = $GLOBALS['MySQL']->escape($_GET['q']); // escaping external data if (! $sParam) exit; switch ($_GET['mode']) { case 'xml': // using XML file as source of data $aValues = $aIndexes = array(); $sFileData = file_get_contents('data.xml'); // reading file content $oXmlParser = xml_parser_create('UTF-8'); xml_parse_into_struct($oXmlParser, $sFileData, $aValues, $aIndexes); xml_parser_free( $oXmlParser ); $aTagIndexes = $aIndexes['ITEM']; if (count($aTagIndexes) <= 0) exit; foreach($aTagIndexes as $iTagIndex) { $sValue = $aValues[$iTagIndex]['value']; if (strpos($sValue, $sParam) !== false) { echo $sValue . "n"; } } break; case 'sql': // using database as source of data $sRequest = "SELECT `country_name` FROM `s85_countries` WHERE `country_name` LIKE '%{$sParam}%' ORDER BY `country_code`"; $aItemInfo = $GLOBALS['MySQL']->getAll($sRequest); foreach ($aItemInfo as $aValues) { echo $aValues['country_name'] . "n"; } break; }
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?php if (version_compare(phpversion(), "5.3.0", ">=") == 1) error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED); else error_reporting(E_ALL & ~E_NOTICE); require_once('classes/CMySQL.php'); $sParam = $GLOBALS['MySQL']->escape($_GET['q']); // escaping external data if (! $sParam) exit; switch ($_GET['mode']) { case 'xml': // using XML file as source of data $aValues = $aIndexes = array(); $sFileData = file_get_contents('data.xml'); // reading file content $oXmlParser = xml_parser_create('UTF-8'); xml_parse_into_struct($oXmlParser, $sFileData, $aValues, $aIndexes); xml_parser_free( $oXmlParser ); $aTagIndexes = $aIndexes['ITEM']; if (count($aTagIndexes) <= 0) exit; foreach($aTagIndexes as $iTagIndex) { $sValue = $aValues[$iTagIndex]['value']; if (strpos($sValue, $sParam) !== false) { echo $sValue . "n"; } } break; case 'sql': // using database as source of data $sRequest = "SELECT `country_name` FROM `s85_countries` WHERE `country_name` LIKE '%{$sParam}%' ORDER BY `country_code`"; $aItemInfo = $GLOBALS['MySQL']->getAll($sRequest); foreach ($aItemInfo as $aValues) { echo $aValues['country_name'] . "n"; } break; }

We filter the resulting data by incoming parameter $_GET[‘q’] from the active text field (where we started typing something). The result – the script gives all matching records. Another one file which we using (as always):

我们通过活动文本字段(我们在此处开始输入内容)中的传入参数$ _GET ['q']过滤生成的数据。 结果–脚本给出了所有匹配的记录。 我们使用的另一个文件(一如既往):

类/CMySQL.php (classes/CMySQL.php)

This is our usual class file to work with database (pretty comfortable). In its constructor you will able to set your own database configuration:

这是我们与数据库一起使用的通常的类文件(非常舒适)。 在其构造函数中,您将能够设置自己的数据库配置:

复制代码
1
2
3
4
5
$this->sDbName = '_DATABASE_NAME_'; $this->sDbUser = '_DATABASE_USERNAME_'; $this->sDbPass = '_DATABASE_USERPASS_';
复制代码
1
2
3
4
5
$this->sDbName = '_DATABASE_NAME_'; $this->sDbUser = '_DATABASE_USERNAME_'; $this->sDbPass = '_DATABASE_USERPASS_';

步骤6. XML (Step 6. XML)

Here are content of our XML data file:

以下是我们的XML数据文件的内容:

data.xml (data.xml)

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<items> <item>1991</item> <item>1990</item> <item>1991</item> <item>1992</item> <item>1993</item> <item>1994</item> <item>1995</item> <item>1996</item> <item>1997</item> <item>1998</item> <item>1999</item> <item>2000</item> <item>2001</item> <item>2002</item> <item>2003</item> <item>2004</item> <item>2005</item> <item>2006</item> <item>2007</item> <item>2008</item> <item>2009</item> <item>2010</item> <item>2011</item> <item>2012</item> <item>2013</item> <item>2014</item> <item>2015</item> </items>
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<items> <item>1991</item> <item>1990</item> <item>1991</item> <item>1992</item> <item>1993</item> <item>1994</item> <item>1995</item> <item>1996</item> <item>1997</item> <item>1998</item> <item>1999</item> <item>2000</item> <item>2001</item> <item>2002</item> <item>2003</item> <item>2004</item> <item>2005</item> <item>2006</item> <item>2007</item> <item>2008</item> <item>2009</item> <item>2010</item> <item>2011</item> <item>2012</item> <item>2013</item> <item>2014</item> <item>2015</item> </items>
现场演示

结论 (Conclusion)

As a result, we see the pattern is obvious – the fastest way – when all possible values are hardcoded in JS. In case of XML and SQL – XML is clearly faster. Just because we even don`t need touch our slow database. I hope that you got interesting lesson for today. Good luck in your work!

结果,当所有可能的值都用JS硬编码时,我们看到的模式是显而易见的-最快的方法。 在使用XML和SQL的情况下-XML显然更快。 仅仅因为我们甚至不需要接触我们缓慢的数据库。 希望您今天能从中学到有趣的一课。 祝您工作顺利!

翻译自: https://www.script-tutorials.com/autocomplete-with-php-jquery-mysql-and-xml/

最后

以上就是朴素短靴最近收集整理的关于使用PHP,jQuery,MySQL和XML自动完成的全部内容,更多相关使用PHP内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(49)

评论列表共有 0 条评论

立即
投稿
返回
顶部