织梦dedecms使用ajax开发搜索下拉提示的教程

92建站   2021-08-16   收藏本文

当使用者在搜索时输入关键字,然后出现下拉菜单,下拉菜单中出现的是站内所有包含关键字的文章的标题共用户选择,与DedeCMS本地搜索这一功能相比,实用一点,既能增加使用者的体验,又能让使用者快速找到想法,今天92建站就带来了织梦使用ajax开发搜索下拉提示的教程。

下面就来说说织梦搜索下拉提示的实现方法。

本功能基于php+jquery来实现,参考autocomplete。

实现教程:

打开你的网站首页模板,在</head>之前加入

<span style="font-family:tahoma,geneva,sans-serif;"><span style="font-size:14px;"><script language="javascript" type="text/javascript" src="{dede:global.cfg_templets_skin/}/js/jquery-1.7.1.min.js"></script>
<script type="text/javascript">   
 function lookup(inputString) {        
if(inputString.length == 0) 
{            
// Hide the suggestion box.            
$('#suggestions').hide();        

else 
{            
$.post("/plus/search_list.php", {queryString: ""+inputString+""}, function(data)

               if(data.length >0) 
{                    
$('#suggestions').show();                    
$('#autoSuggestionsList').html(data);               
 }            
});        
}    
} // lookup        
function fill(thisValue) {        
$('#inputString').val(thisValue);        
setTimeout("$('#suggestions').hide();", 200);    
}
 </script></span></span>

jquery-1.7.1.min.js这个jquery库需要你自己下载,这里就不多说了。本人用的是这个版本的。

这段代码中的search_list.php就是本文下载的文件,下载后放入/plus目录下。

打开head.htm,找到搜索部分的from表单代码修改为

<span style="font-family:tahoma,geneva,sans-serif;"><span style="font-size:14px;"><form name="formsearch" action="{dede:global.cfg_cmsurl/}/plus/search.php" id="formkeyword">
    <label for="header-subscribe-email" class="text"></label><input type="hidden" name="kwtype" value="0"/><input type="text" name="q" size="24" value="在这里搜索..." onfocus="if(this.value=='在这里搜索...'){this.value='';}" onblur="if(this.value==''){this.value='在这里搜索...';}" id="inputString" onkeyup="lookup(this.value);" onblur="fill();" class="f-text"><input type="submit" class="commit" value="搜索"/>
    <div class="suggestionsBox" id="suggestions" style="display: none;">
        <div class="suggestionList">
            <ul id="autoSuggestionsList">
            </ul>
        </div>
    </div>
</form></span></span>

这部分可以根据你自己的代码的实际情况具体修改,主要是输入关键字的input和下边加的DIV层。

打开你自己的样式表css文件,在最后加入

<span style="font-family:tahoma,geneva,sans-serif;"><span style="font-size:14px;">.suggestionsBox {
    position: relative;
    left: 0px;
    width: 250px;
    background: white;
    border: 1px solid #dcdcdc;
    color: #323232;
    z-index: 999;
}

.suggestionList {
    margin: 0px;
    padding: 0px;
}

.suggestionList li {
    margin: 0px 0px 3px 0px;
    position: relative;
    padding: 3px;
    cursor: pointer;
    list-style: none;
    padding-left: 5px;
    height: 20px;
    overflow: hidden
}

.suggestionList li:hover {
    background-color: #659CD8;
}

.jr {
    position: absolute;
    top: 9px;
    right: -5px
}</span></span>

 

到这添加的代码就完了,然后下载search_list.rar,下载后解压得search_list.php到放入/plus目录下。在这个文件里有详细注解。可根据实际情况调整。所有结果都是由这个文件来返回的。最后去前台试试您的效果把。

    展开