Ajax实现搜索文本框自动联想功能

以下是一个使用jQuery和Ajax实现搜索文本框自动联想功能的简单示例:

HTML部分:




<input type="text" id="search-input" placeholder="搜索...">
<div id="autocomplete-results">
  <!-- 自动联想的结果将被插入到这里 -->
</div>

CSS部分:




#autocomplete-results {
  border: 1px solid #999;
  cursor: default;
  position: absolute;
  z-index: 1000;
  top: 100%;
  left: 0;
  display: none;
}
 
#autocomplete-results li {
  padding: 5px 10px;
  background: #FFF;
  display: block;
  border-bottom: 1px solid #EEE;
}
 
#autocomplete-results li:hover {
  background: #F0F0F0;
}

JavaScript部分(使用jQuery和Ajax):




$(document).ready(function() {
  $('#search-input').keyup(function() {
    var inputVal = $(this).val();
    var resultDropdown = $(this).siblings("#autocomplete-results");
    if(inputVal.length){
      $.ajax({
        type: "GET",
        url: "your-autocomplete-api-endpoint.php",
        data: 'input='+inputVal,
        success: function(data){
          // 假设返回的数据是JSON格式
          var data = JSON.parse(data);
          resultDropdown.empty();
          $.each(data.results, function(key, value) {
            resultDropdown.append($("<li></li>").text(value));
          });
          resultDropdown.show();
        }
      });
    } else{
      resultDropdown.empty();
      resultDropdown.hide();
    }
  });
 
  $(document).on("click", "#autocomplete-results li", function() {
    var text = $(this).text();
    $('#search-input').val(text);
    $('#autocomplete-results').empty();
    $('#autocomplete-results').hide();
  });
});

后端PHP示例(your-autocomplete-api-endpoint.php):




<?php
// 假设你有一个方法来处理搜索和获取结果
$input = $_GET['input'];
$results = getAutocompleteSuggestions($input); // 自定义方法获取建议
 
header('Content-Type: application/json');
echo json_encode(['results' => $results]);

确保替换your-autocomplete-api-endpoint.php为你的实际后端API端点。这个PHP脚本应该根据输入的值返回相应的自动完成建议。

最后修改于:2024年08月25日 19:26

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日