繁体   English   中英

jQuery使用PHP和MySQL基于一个字段自动完成两个字段

[英]Jquery autocomplete two fields based on one field using PHP and MySQL

我在MySQL数据库中有一个表,其中包含以下几列:名称,地址,职业,电话号码和序列号。 在我的html表单中,除其他字段外,我还有用于输入名称,电话号码和序列号的文本字段。 如何使用jQuery自动完成功能和PHP / MySQL使用“序列号”字段填充“名称”和“电话号码”字段? 我已经设法在一个输入字段上设置自动填充,但是我不知道如何使用具有自动完成功能的一个字段将其设置为填充其他两个字段。 谢谢

这些是领域

   <input type="text" name="name" id="autocomplete" />
   <input type="text" name="phone_number" id="autocomplete" />
   <input type="text" name="serial_number" id="autocomplete" />

这是我的php脚本,用于从db获取字符串

<?php
$dbhost = 'YOUR_SERVER';
$dbuser = 'YOUR_USERNAME';
$dbpass = 'YOUR_PASSWORD';
$dbname = 'YOUR_DATABASE_NAME';

$conn = mysql_connect($dbhost, $dbuser, $dbpass) or die ('Error connecting to mysql');
mysql_select_db($dbname);

$return_arr = array();

if ($conn)
{
    $fetch = mysql_query("SELECT name, phone_number, serial_number FROM users");


    while ($row = mysql_fetch_array($fetch, MYSQL_ASSOC)) {
        $row_array['value'] = $row['name'] . " " . $row['phone_number'] " . $row['serial_number'] ";         
        array_push($return_arr,$row_array);
    }


}
mysql_close($conn);
echo json_encode($return_arr);
?>

您需要做的是,当序列号的自动完成完成时,运行一个ajax调用以根据序列号检索名称和电话号码,然后填充这些字段,如下所示:

$('input[name=serial_number]').autocomplete({
    onComplete: function (val) {
        $.getJSON('/url-to-fetch-name-and-phone.php?serial_number=' + val, function (data) {
            $('input[name=name]').val(data.name);
            $('input[name=tel]').val(data.tel);
        });
    }
});

显然,您需要根据设置更改一些函数和变量名称。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM