


Today I suddenly wanted to make a search page for this site, so that users can find their favorite content through search, and also avoid the trouble of manually finding resources in massive information. My goal is the effect of Baidu homepage Similarly, when the user enters the text to be searched, we provide ten relevant pieces of information below. If the user is looking for one of these ten pieces of information, it is simple. Just click to open the page in a new page. Mainly I just want to be more user-friendly and make it more convenient for users to use.
Let’s take a look at the renderings first. This will give you more motivation, otherwise you won’t know what I’m talking about and what effect I want to achieve!
The following mainly explains the principle:
In the search.html page, when the user enters "j" in the search box, use javascript to obtain the text content of the search box, search for relevant content in the database and return it, and then use javascript to display the results returned by the server in The prompt box below the search box is for users to make reference choices.
Specific implementation method:
First, create a search box, a search button, and a layer that displays search prompts on the page, as shown in the following code
<div id="search">
<br>
<input type="text" name="k" class="k"> <input type="button" name="s" value="搜索"><br>
</div>
<br>
<div id="search_auto"></div>
Use the browser to browse the page, and you will see the effect below
It looks very ordinary and has no style. Now let’s make some adjustments to the style
#search{font-size:14px;}<br>
#search .k{padding:2px 1px; width:320px;} /*将搜索框宽度设置大点*/
Then adjust the style of the layer that displays the search prompt. Since the search prompt layer is directly below the search box, we set its positioning method to absolute positioning
#search_auto{border:1px solid #817FB2; position:absolute;} /*Set the border and positioning method*/
Then use JS to place the search prompt layer directly below the search box, and the width is the same as the search box. Here we use jQuery to solve the problem
$(#search_auto).css({width:$(#search input[name="k"]).width()+4});
The position and width of the search prompt layer have been determined. Since the prompt box will not be displayed before the user enters the search text, we first need to set it to hidden and add display to the style of the prompt layer: none hides it.
Everything is OK. Now we only need to register the event for the onkeyup of the search box. We still use jQuery to handle it. In jQuery, it is keyup
$(#search input[name="k"]).keyup(function(){<br>
$.post(search_auto.php,{value:$(this).val()},function(data){ //向服务器上的search_auto.php发送post数据,$.post是jQuery的方法<br>
if(data==0) $(#search_auto).html().css(display,none); //判断服务器上返回的数据,如果等于0,则表示没有找到相关的内容,所以将提示框的内容清空并隐藏<br>
else $(#search_auto).html(data).css(display,block); //如果服务器上返回的数据不等于0,则将返回的内容放到提示框内并显示提示框<br>
});<br>
});
The above client has been completed and can send the user input to the server and respond to the server’s return value.
So how does the server process the data sent by the client? Let’s use PHP as an example
<?php <br />
$v=$_POST[value];<br>
$re=mysql_query("select * from test where title like %$v% order by addtime desc limit 10"); //根据客户端发送来的数据,到数据库中查询10条相关的结果<br>
if(mysql_num_rows($re)
echo <ul>;<br>
while($ro=mysql_fetch_array($re)) echo <li><a href="">.$ro[title].</a></li>; //将查询得到的相关结果的标题输出,这个地方需要注意,由于通过jQuery的ajax技术返回的文本是UTF-8编码,所以如果$ro[title] 中包含中文,一定要记得用PHP的iconv或其它函数将其转换成UTF-8编码,否则在页面中看到的会是一串乱码<br>
echo <li class="cls">
<a href="javascript:;" onclick="$(this).parent().parent().parent().fadeOut(100)">关闭</a>& gt;</li>; //输入一个关闭按钮,让用户不想看到提示层时可以点击关闭,关闭按钮采用jQuery,解释一下,当前点击的按钮是$(this),一直向上找到其第三个父元素,让它逐渐消失<br>
echo </ul>;<br>
?>
Now the server can correctly execute the data we sent and return the corresponding results. Now enter a text in the search box to test it, but the premise is that there must be something related to this text in your database. content, otherwise you wouldn’t see the prompt box appear because there is no relevant prompt content, haha.
But there is still a slight flaw, that is, the content in the prompt box is not beautiful. Compared with the prompt box we saw in Baidu search, it is simply too ugly. Haha, don’t worry, we will use css to adjust the display. The effect of
#search_auto li{background:#FFF; text-align:left;} /*设置提示框内的li标签效果*/<br>
#search_auto li.cls{text-align:right;} /*设置提示框内的关闭按钮效果*/<br>
#search_auto li a{display:block; padding:5px 6px; cursor:pointer; color:#666;} /*设置提示框内li标签下的a标签效果*/<br>
#search_auto li a:hover{background:#D8D8D8; text-decoration:none; color:#000;} /*当鼠标移入提示框内时的效果*/
Now it is truly fully completed. As for whether to set up a delay processing or other more complete functions, it is left to friends to use their own brains. You can also reply to your thoughts below, etc.
Complete client code:
<div id="search">
<br>
<input type="text" name="k" class="k"> <input type="button" name="s" value="搜索"><br>
</div>
<br>
<div id="search_auto"></div>
<script><br />
$(function(){<br />
<br />
$(#search_auto).css({width:$(#search input[name="k"]).width()+4});<br />
$(#search input[name="k"]).keyup(function(){<br />
$.post(search_auto.php,{value:$(this).val()},function(data){<br />
if(data==0) $(#search_auto).html().css(display,none);<br />
else $(#search_auto).html(data).css(display,block);<br />
});<br />
});<br />
<br />
});<br />
</script>
Server-side complete code:
<?php <br />
$v=$_POST[value];<br>
$re=mysql_query("select * from test where title like %$v% order by addtime desc limit 10");<br>
if(mysql_num_rows($re)
echo <ul>;<br>
while($ro=mysql_fetch_array($re)) echo <li><a href="">.$ro[title].</a></li>;<br>
echo <li class="cls">
<a href="javascript:;" onclick="$(this).parent().parent().parent().fadeOut(100)">关闭</a>& gt;</li>;<br>
echo </ul>;<br>
?>

随着互联网的发展,SEO(SearchEngineOptimization,搜索引擎优化)已经成为了网站优化的重要一环。如果您想要使您的PHP网站在搜索引擎中获得更高的排名,就需要对SEO的内容有一定的了解了。本文将会介绍如何在PHP中实现SEO优化,内容包括网站结构优化、网页内容优化、外部链接优化,以及其他相关的优化技巧。一、网站结构优化网站结构对于S

随着电子商务和企业管理的发展,许多企业开始寻找更好的方法来处理其日常业务流程。ERP系统是一种能够整合企业各种业务流程的软件工具。它提供了全面的功能,包括生产、销售、采购、库存、财务等方面,帮助企业提高效率、控制成本和提高客户满意度。而在PHP编程语言中,也能够实现ERP系统,这就需要我们掌握一些基本的知识和技术。下面,我们将深入探讨如何在PHP中实现ERP

随着物联网技术的发展和普及,越来越多的应用场景需要使用PHP语言进行物联网开发。PHP作为一种广泛应用于Web开发的脚本语言,它的易学易用、开发速度快、可扩展性强等特点,使其成为开发物联网应用的一种优秀选择。本文将介绍在PHP中实现物联网开发的常用技术和方法。一、传输协议和数据格式物联网设备通常使用TCP/IP或UDP协议进行数据传输,而HTTP协议是一个优

随着企业的发展,客户管理变得越来越重要。为了提高客户满意度和忠诚度,越来越多的企业采用客户关系管理系统(CRM)来帮助其管理客户关系。而PHP是一种流行的编程语言,因其简单易学、灵活和强大而被广泛应用于Web开发。那么,如何在PHP中实现CRM系统呢?本文将为您介绍实现CRM系统的步骤和技巧。Step1:需求分析在开始开发CRM系统之前,您需要进行需求分析

随着互联网的发展,轮播图已经成为了网页设计中必不可少的一部分。在很多网页中,轮播图经常被用作展示企业文化、最新产品或是推广活动等场景。本篇文章将会分享如何使用PHP来实现轮播图的功能。一、轮播图的概念轮播图是网页中一种常见的视觉效果,一般由多个图片组成,在页面中自动或手动进行切换,展示多个内容。可以添加符合业务要求的动画效果,有助于引起用户的关注和提高网站的

随着互联网的不断发展,越来越多的网站需要使用验证码来保证安全性。验证码是一种借助人类能力而无法被计算机破解的认证技术,广泛应用于网站注册、登录、找回密码等功能中。下面将介绍如何使用PHP实现验证码功能。一、生成验证码图片验证码图片的生成是验证码功能的核心,需要生成一个随机字符,并将其渲染为图像展示给用户。在PHP中,可以使用GD库来生成图片。GD库是一种用于

智能合约(SmartContract)是一种基于区块链的自动化交易程序,可以实现自动化执行、验证和执行交易。智能合约可以减少交易中的人为干扰,提高交易的安全性和效率。在不同的区块链中,智能合约的实现方式略有不同。本文将介绍在PHP中如何实现智能合约。PHP是一种广泛使用的编程语言,特别适合Web开发。PHP有着成熟的开源生态系统,以及许多可靠的框架和库。在

随着移动互联网的发展,微信已经成为了人们生活中不可或缺的一部分,越来越多的商家选择在微信平台上开展业务。实现微信支付功能对于商家来说是非常必要的。本文将介绍如何使用PHP实现JSAPI支付。首先,我们需要了解什么是JSAPI支付。JSAPI是微信公众号支付功能的一种,通过JS调用微信支付接口实现支付。JSAPI支付的优点在于用户只需要在微信中进行支付,不需要


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

WebStorm Mac version
Useful JavaScript development tools

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software
