正常情况下,我们只需要普通的wordpress主题搜索框功能。但有时会碰到一些追求完美的客户,这不,前段时间就有这样一位客户,要求在wordpress主题搜索框中输入时,要在输入框下显示对应的关键词列表,并且要求被输入的字符在下拉列表中显示为红色。那么如何才能让WordPress主题在搜索框输入时显示下拉关键词列表?
这肯定需要JS来实现了。当然,网上这方面的JS插件也是非常多的。但是需要自己去修改里的代码,这样比较麻烦,还不如自己来一句一句地写呢。其实,实现起耿也不是那么的难。
思路:就是在wordpress主题的搜索框中每输入一个字符时,就要触发一个事件——向数据库发送请求——搜索这个输入的字符相关的信息。
这里会用到 键盘按下弹起事件,用到ajax发送请求。不多说,按步骤来。
第一步:wordpress主题搜索框代码:
” class=”search-field ku-input ” value=”” name=”s” />
第二步:处理下拉的JS代码:
//根据输入框中的事件来做的事情 使用keyup来判断是否要发送请求,使用keyup在输入完词以后就会立即发送请求var now=-1; //声明一个变量值为-1,是为了在使用上下键的时候记录li的序号var resLength=0; //这个变量是为了存li的长度$(‘.search-field').keyup(function(event){if(event.keyCode==38 || event.keyCode==40){ //每按一次上下键都会发送一次请求,所以要先return; //清除一边请求};var ss = $(‘.search-field').val();if( ss != ” ){ //当输入框的值不为空的时候才能发送请求$.ajax({type:”post”,url:”/search_get.php”, //接口文件。这里的 THEME_PATH是我声明的一个常量:当前主题路径async:true,data:{ ss:ss, act:'dropdown_list”},success:function(res){var arr = eval(res);$(‘#search ul').html(“”); //先清空ul里的内容for(var i=0;i resLength=arr.length;var title = arr[i].post_title;title = title.replace(ss,''+ss+'');oli_i=$(‘'+ title +' ');$(‘#search ul').append(oli_i);//要实现点击某一条词的时候也能让输入框中出现点击的这条词,所以要在success里面设置$(‘#search ul li').eq(i).click(function(){$(‘.search-field').val($(this).text());$(this).addClass(‘current').siblings().removeClass(‘current')})};$(‘#search ul').slideDown(); //显示下拉},error:function(res){console.log(res)}});}else{$(‘#search ul').html(”) //如果输入框的词都删除了,把获取的数据结果也清空,$(‘#search ul').slideUp();};});//在输入框中按上下键的时候对应的每一条数据的样式要有改变,这里使用了keydown这个事件足够了$(‘.search-field').keydown(function(ev){if(ev.keyCode==40){ //按下键时,now应该变大now++;$(‘#search ul li').eq(now).addClass(‘current').siblings().removeClass(‘current')$(‘.search-field').val($(‘#search ul li').eq(now).text())//resLength表示的是长度,now表示的是序号,所以要用resLength-1if(now==resLength-1){now=-1; //当选择的数据已经到了最底部的时候,就要从顶部开始重新循环,所以now又回到-1}};if(ev.keyCode==38){now–; //按上键的时候,光标往上走,所以now减小$(‘#search ul li').eq(now).addClass(‘current').siblings().removeClass(‘current');$(‘.search-field').val($(‘#search ul li').eq(now).text())if(now<-1){now=resLength-1 //当光标走到最上面的时候,再循环到底部重新往上走};};});$(‘.search-field').blur(function(){$(‘#search ul').slideUp();})第三步:ajax提交的接口:search_get.php
//ajax 根据输入框 内容 变化,来搜索结果,展示出下拉搜索列表define(‘BASE_PATH',str_replace( ‘\' , ‘/' , realpath(dirname(__FILE__).'/../../../')));//获取根目录require(BASE_PATH.'/wp-load.php' );global $wpdb;if($_POST[‘act']=='dropdown_list'){$ss = esc_sql($_POST[‘ss']);if($ss){$sql = “select post_title from wp_posts where post_status='publish' and post_title like ‘%$ss%' limit 8”;$res = $wpdb->get_results($sql);echo json_encode($res);}}通过上面的三步,我们就为wordpress主题的搜索框实现了下拉列表,当我们在这个搜索框中输入时,就会在搜索框的下面展示我们正在输入的内容的相对应的下拉列表。如果你也对这样的效果感兴趣,不妨也试试吧。
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《如何才能让WordPress主题在搜索框输入时显示下拉关键词列表?》
文章链接:https://www.ibytx.com/2087.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。相关推荐
#618大促#最后一天|凌霞软件旗下强大易用的建站工具 Halo:永久授权 660元起,10台6000元,即买即赠SSL证书
#6.18促销#Themebetter:WordPress主题特惠7折,DUX主题折后559元,不限制域名授权数目
#20周年庆典#SiteGround:稳定博客/外贸主机,免费站点转移/电子邮件/SSL证书/CDN和备份服务等,月付$2.99/年付35.88美元起
#圣诞节促销#Hostarmada:共享主机80%优惠,低至$1.99/月起,vps和经销商主机50%优惠,$19.6/月起,可选新加坡/法兰克福等9个机房
#4周年庆典#Hostarmada:共享主机80%优惠,低至$1.99,vps和经销商主机50%优惠,可选新加坡/法兰克福等9个机房
#黑五优惠预告#SiteGround:WordPress主机/外贸主机最高优惠85%,同样服务全年最低价格,月付$1.99起
#11.11#Themebetter:年度大放价,全场6折特惠,DUX主题折后480元,不限制域名授权数目
FastComet:2023黑五早鸟活动开启, 美国虚拟主机2折促销,月付$2.19起

博悦天下











