DEDE集成百度搜索谷歌搜索站内全站搜索站内按栏目搜索等功能的搜索栏

所属分类: CMS教程 / dedecms 阅读数: 941
收藏 0 赞 0 分享

DEDE可定制性非常强,我们接到一个项目,要求定制站点的搜索框,要求能有个选项,可以让访客点选使用百度搜索站内内容或者用谷歌搜索站点内容,或者直接搜索整站内容,或者点选按栏目搜索站内内容

全部代码如下:

<div class="search-bg">
  <div class="inner">
    <div class="search-form">
   <form role="search" method="get" id="searchform" name=bf onSubmit="bottomForm();return false;">
<script> 
function bottomForm(){
var $=document.bf.key.value; 
var $2=document.bf.sto.value; 
if(document.bf.sto[0].selected)window.open("https://www.baidu.com/s?wd="+"site%3Abnxb.com+"+$); 
if(document.bf.sto[1].selected)window.open("https://www.google.com.hk/search?hl=zh-CN&source=hp&q="+"site%3Awww.bnxb.com+"+$);
if(document.bf.sto[2].selected)window.open("{dede:global.cfg_basehost/}/app/search.php?kwtype=1&keyword="+$); 
else window.open("{dede:global.cfg_basehost/}/app/search.php?kwtype=1&keyword="+$+"&typeid="+$2);
return false} 
</script>
<input name="key" id="s" class="s" value="请输入关键词开始搜索!"onClick="this.value = '';" style="background-color: rgb(255, 255, 255); color: rgb(153, 153, 153); opacity: 0.8664601413572597; background-position: initial initial; background-repeat: initial initial; "onKeyPress="javascript:if(event.keyCode == 13){query(this.value);}" x-webkit-speech="" type="text">
<SELECT class="search-select" name="sto" id="search-option"> 
               <option value="0" class="search-select-option">百度搜索</option>
               <option value="1111" class="search-select-option">谷歌搜索</option>
   <option value="2222" selected='1' class="search-select-option">全站搜索</option>
{dede:channelartlist typeid='top' }
{dede:type} <option value='[field:id/]'>[field:typename/]</option>{/dede:type}
{dede:channel type='son' noself='yes'}
<option value='[field:id/]'>--[field:typename/]</option>
{/dede:channel}
{/dede:channelartlist}
</select>
<button id="searchsubmit" class="btn">搜索</button>
</form>
    </div>
    <div class="tagscloud"> <span>快捷搜索:</span>  {dede:hotwords num='5'subday='30' maxlength='10'/}   </div>
  </div>
</div>

CSS如下

/*search-bg*/
.search-bg {background-color:#F5F5F5; width:100%; padding:20px 0; display:none;}
.search-bg.search-open {display:block;}
.search-bg .inner {overflow:hidden;}
.search-form,.search-form input {float:left;}
.search-form .s {background-color:#fff; border:1px solid #ddd; height:22px; line-height:22px; padding:5px; font-size:0.875em; width:500px; border-radius:3px;}
.search-form button {border:none; background-color:#1e82aa; color:#fff; height:32px; padding:0 10px; cursor:pointer; margin:1px 0px; border-radius:6px; font-size:1em;}
.search-form .search-select {background-color:#fff; border:1px solid #ddd; height:34px; line-height:34px; margin:1px 5px;}
.search-form .search-select-option {background-color:#E9EAEC;font-weight:bold}

其实就是笨牛网的搜索框项目,就是用的这个方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Dedecms自定义模型解决会员无法投稿的方法

这篇文章主要为大家介绍了Dedecms自定义模型解决会员无法投稿的方法,通过新建文章模型与栏目实现会员投稿功能,是dedecms二次开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS新建模型字段中【附件样式】的修改方法

这篇文章主要为大家介绍了DedeCMS新建模型字段中【附件样式】的修改方法,是dedecms二次开发中针对字段操作的典型应用,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms的sql标签中传入参数的方法

这篇文章主要为大家介绍了dedecms的sql标签中传入参数的方法,是进行dedecms数据库程序开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

织梦dede后台卡、假死解决方法

用过织梦的网友,特别是dede栏目或是数据非常多的情况下,我们从后台第一次登录的话,不少网友都会发现登录完一般都会出现dede后台卡,或是dede后台卡死,或是非常卡的情况
收藏 0 赞 0 分享

DEDECMS内容页分页过多、过长问题最佳解决方案

最近由于我们网站添加了图片栏目,小编一个图片就分一页这样的话,我们的内容页面的分页就很多,10几个分页一页显示比较难看,所以想到了用这个方法,感觉网友的分享
收藏 0 赞 0 分享

dedecms调用当前栏目的子栏目的两种方法分享

dedecms大家想必不会陌生,算是国内使用较为广泛的一款文章类CMS系统了,使用过程中也许我们需要用到调用当前栏目的子栏目,那么应该如何操作呢,下面我们来分享2种方法
收藏 0 赞 0 分享

dedecms实现列表页缩略图随机调用的方法

这篇文章主要为大家介绍了dedecms实现列表页缩略图随机调用的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms搬家时出现数据库导入失败的解决方法

这篇文章主要为大家介绍了dedecms搬家时出现数据库导入失败的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms实现将表单订单发送到邮箱实例代码

这篇文章主要为大家介绍了dedecms实现将表单订单发送到邮箱的实现方法,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS实现MySQL修复表的方法

DedeCMS用户碰到数据表出现报错“dede_search_keywords' is marked as crashed and should be repaired”的情况下,就需要对MySQL数据表进行修复。这篇文章主要为大家介绍了DedeCMS实现MySQL修复表的方法,
收藏 0 赞 0 分享
查看更多