Heim > Artikel > Backend-Entwicklung > Verwenden Sie PHP und Xunsearch, um die Funktion zur automatischen Vervollständigung von Suchbegriffen zu implementieren
Mit PHP und In der PHP-Entwicklung kann diese Funktion mithilfe der Suchmaschinenbibliothek Xunsearch erreicht werden. In diesem Artikel wird erläutert, wie Sie mithilfe von PHP und Xunsearch die Funktion zur automatischen Vervollständigung von Suchschlüsselwörtern implementieren.
Zuerst müssen wir einen Xunsearch-Suchmaschinendienst aufbauen. Sie können das Installationspaket und die Anleitung in der offiziellen Dokumentation von Xunsearch verwenden, um die Einrichtung abzuschließen. Nachdem die Einrichtung abgeschlossen ist, müssen Sie das von Xunsearch bereitgestellte SDK verwenden, um eine Verbindung zum Suchmaschinendienst herzustellen.
In PHP können Sie die von Xunsearch bereitgestellten Klassen verwenden, um Suchvorgänge durchzuführen. Das Folgende ist ein einfacher Beispielcode:
<?php require_once('/path/to/xunsearch/lib/XS.php'); $xs = new XS('demo'); // 创建一个XS实例,参数为项目名称 $search = $xs->search; // 获取搜索对象 $word = $_GET['keyword']; // 获取用户输入的关键词 $search->setLimit(10); // 设置需要返回的搜索结果数量 $query = new XSTokenizerScws($word); // 创建一个分词器 $search->setQuery($query); // 设置搜索关键词 $search->setFuzzy(true); // 设置模糊搜索 $docs = $search->search(); // 执行搜索操作 $result = array(); foreach ($docs as $doc) { $result[] = $doc->title; //将搜索结果的标题添加到结果数组中 } echo json_encode($result); // 将结果数组转换为JSON格式并返回给前端
Der obige Code implementiert eine Fuzzy-Suche basierend auf den vom Benutzer eingegebenen Schlüsselwörtern und gibt den Titel der Suchergebnisse zurück. Unter diesen erhält $xs->search
ein Suchobjekt, $search->setQuery($query)
legt das Suchschlüsselwort fest, $search- > ;setFuzzy(true)
aktiviert die Fuzzy-Suche und $search->search()
führt den Suchvorgang aus.
Damit die Funktion zur automatischen Vervollständigung wirksam wird, müssen wir Echtzeitsuchen und Eingabeaufforderungen durchführen, wenn der Benutzer etwas in das Eingabefeld eingibt. Dies kann mithilfe der AJAX-Technologie erreicht werden. Das Folgende ist ein einfaches Front-End-Codebeispiel: $xs->search
获取了一个搜索对象,$search->setQuery($query)
设置了搜索关键词,$search->setFuzzy(true)
开启了模糊搜索,$search->search()
执行了搜索操作。
为了使自动补全功能生效,我们需要在用户在输入框输入时进行实时的搜索和提示。可以使用AJAX技术来实现。下面是一个简单的前端代码示例:
<!DOCTYPE html> <html> <head> <title>搜索关键词自动补全</title> <script src="https://cdn.staticfile.org/jquery/3.6.0/jquery.min.js"></script> </head> <body> <input type="text" id="keyword" placeholder="请输入关键词"> <ul id="result"></ul> <script> $(function() { $("#keyword").on('input', function() { var keyword = $(this).val(); $.ajax({ url: "search.php", type: "GET", data: { keyword: keyword }, success: function(response) { var result = JSON.parse(response); var html = ""; for (var i = 0; i < result.length; i++) { html += "<li>" + result[i] + "</li>"; } $("#result").html(html); } }); }); }); </script> </body> </html>
上述前端代码通过监听输入框的input
事件来实现实时搜索和提示。每当用户输入发生变化时,会向后端的search.php
发送GET请求,并将用户输入的关键词作为参数传递。后端返回的结果通过动态生成25edfb22a4f469ecb59f1190150159c6
rrreee
input
-Ereignis des Eingabefelds abhört. Immer wenn sich die Benutzereingabe ändert, wird eine GET-Anfrage an das Backend search.php
gesendet und die vom Benutzer eingegebenen Schlüsselwörter werden als Parameter übergeben. Die vom Backend zurückgegebenen Ergebnisse werden auf der Seite angezeigt, indem 25edfb22a4f469ecb59f1190150159c6
-Elemente dynamisch generiert werden. Zusammenfassend lässt sich sagen, dass es nicht kompliziert ist, PHP und Xunsearch zu verwenden, um die automatische Vervollständigungsfunktion von Suchbegriffen zu realisieren. Durch die Konfiguration der Xunsearch-Suchmaschine und das Schreiben des entsprechenden PHP- und Front-End-Codes kann eine einfache und effiziente Suchvervollständigungsfunktion implementiert werden, um die Genauigkeit und Erfahrung der Benutzersuche zu verbessern. 🎜Das obige ist der detaillierte Inhalt vonVerwenden Sie PHP und Xunsearch, um die Funktion zur automatischen Vervollständigung von Suchbegriffen zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!