ecshop搜索栏效果如下

所需要的样式我们可以复制到style.css里:

  1. /*搜索滑动效果*/
  2. .Menu {
  3. position:absolute;
  4. top:30px;
  5. left:7px;
  6. width:150px;
  7. height:auto;
  8. z-index:1;
  9. background:#FFF;
  10. border:1px solid #000;
  11. display:none;
  12. }
  13. .Menu2 {
  14. position: absolute;
  15. left:0;
  16. top:0;
  17. width:100%;
  18. height:auto;
  19. overflow:hidden;
  20. z-index:1;
  21. }
  22. .Menu2 ul{margin:0;padding:0}
  23. .Menu2 ul li{width:100%;height:25px;line-height:25px;text-indent:15px;
  24. border-bottom:1px dashed #ccc;color:#666;cursor:pointer;background:#FFF;
  25. change:expression(
  26. this.onmouseover=function(){
  27. this.style.background="#F2F5EF";
  28. },
  29. this.onmouseout=function(){
  30. this.style.background="";
  31. }
  32. )
  33. }
  34. input{width:200px}
  35. .form{width:200px;height:auto;}
  36. .form div{position:relative;top:0;left:0;margin-bottom:5px}

复制代码

以下代码需要加到输入框普遍 比如page_header.lbi

  1. <script type="text/javascript">
  2. function showAndHide(obj,types,text){
  3. var Layer=window.document.getElementById(obj);
  4. switch(types){
  5. case "show":
  6. if(text!='')
  7. {
  8. Layer.style.display="block";
  9. Ajax.call('search_div.php', 'act=search&text=' + text, changesumResp**e, 'GET', 'JSON');
  10. }
  11. break;
  12. case "hide":
  13. Layer.style.display="none";
  14. }
  15. }
  16. function getValue(obj,str){
  17. var input=window.document.getElementById(obj);
  18. input.value=str;
  19. }
  20. function changesumResp**e(res)
  21. {
  22. var a='';
  23. for (var i = 0; i < res.content.length; i++)
  24. {
  25. a += "<li onmousedown=getValue('keyword','" + res.content[i].goods_name + "')>" + res.content[i].goods_name + "</li>";
  26. }
  27. // alert(a);
  28. document.getElementById('show_stock').innerHTML = a;
  29. }
  30. </script>

复制代码

我们输入框的代码

  1. <input name="keywords" onkeyup="showAndHide('List1','show',this.value);" onblur="showAndHide('List1','hide');" type="text" id="keyword" value="{$search_keywords|escape}" style=" border:0; margin-left:15px;margin-top:5px; width:130px; height:15px;"/>
  2. <div class="Menu" id="List1">
  3. <div class="Menu2">
  4. <ul style="padding:0px; margin:0px;" id="show_stock">
  5. </ul>
  6. </div>
  7. </div>

复制代码

ajax请求php的代码

search_div.php

  1. <?php
  2. define('IN_ECS', true);
  3. require(dirname(__FILE__) . '/includes/init.php');
  4. require(dirname(__FILE__) . '/admin/includes/lib_main.php');
  5. if($_REQUEST['act'] == 'search'){
  6. $keywords = json_str_iconv(trim($_GET['text']));
  7. $sql = "SELECT goods_name,goods_id FROM " . $GLOBALS['ecs']->table('goods')." where goods_name like '%$keywords%'";
  8. $brand_array = $GLOBALS['db']->getall($sql);
  9. foreach($brand_array as $ids =>$value)
  10. {
  11. $brand_array[$ids]['goods_name'] = sub_str_xaphp($brand_array[$ids]['goods_name'],5);
  12. }
  13. make_json_result($brand_array);
  14. }
  15. function sub_str_xaphp($str, $length = 0, $append = true)
  16. {
  17. $str = trim($str);
  18. $strlength = strlen($str);
  19. if ($length == 0 || $length >= $strlength)
  20. {
  21. return $str;
  22. }
  23. elseif ($length < 0)
  24. {
  25. $length = $strlength + $length;
  26. if ($length < 0)
  27. {
  28. $length = $strlength;
  29. }
  30. }
  31. if (function_exists('mb_substr'))
  32. {
  33. $newstr = mb_substr($str, 0, $length, EC_CHARSET);
  34. }
  35. elseif (function_exists('iconv_substr'))
  36. {
  37. $newstr = iconv_substr($str, 0, $length, EC_CHARSET);
  38. }
  39. else
  40. {
  41. //$newstr = trim_right(substr($str, 0, $length));
  42. $newstr = substr($str, 0, $length);
  43. }
  44. if ($append && $str != $newstr)
  45. {
  46. $newstr .= '';
  47. }
  48. return $newstr;
  49. }
  50. ?>

复制代码

在商品少的情况下 我们之间查询 如果多了,最模板建议修改程序

ecshop搜索出现相关商品的效果滑动下拉效果的更多相关文章

  1. jQuery手写几个常见的滑动下拉菜单 分分秒秒学习JS

    一般的企业网站再我们再实际工作中,有些特效,用jQuery来做,显得极其简单,除非一些大的公司,需要封装自己的类. 今天,我们讲解jQuery入门知识,来写几个简单jQuery滑动下拉菜单.感受一下j ...

  2. jQuery实现折叠下拉效果

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  3. Android 聊天表情输入、表情翻页带效果、下拉刷新聊天记录

    经过一个星期的折腾,最终做完了这个Android 聊天表情输入.表情翻页带效果.下拉刷新聊天记录.这仅仅是一个单独聊天表情的输入,以及聊天的效果实现.由于我没有写server,所以没有两方聊天的效果. ...

  4. Easy UI combobox实现类似 Select2的效果,下拉带搜索框

    一直在开发一个新系统,其中用Easy UI作为前端框架,少不了用 combobox做为一个 下拉控件,它支持 可编辑 模糊本地数据过滤,也可支持 不可编辑 下拉 选择的功能: $('#ID' ).co ...

  5. MVC身份验证.MVC过滤器.MVC6关键字Task,Async.前端模拟表单验证,提交.自定义匿名集合.Edge导出到Excel.BootstrapTree树状菜单的全选和反选.bootstrap可搜索可多选可全选下拉框

    1.MVC身份验证. 有两种方式.一个是传统的所有控制器继承自定义Control,然后再里面用MVC的过滤器拦截.所以每次网站的后台被访问时.就会先走入拦截器.进行前端和后端的验证 一个是利用(MVC ...

  6. Android抽屉(SlidingDrawer --类似android通知栏下拉效果)

    Android抽屉(SlidingDrawer)的实现发 - 红黑联盟http://www.2cto.com/kf/201301/182507.html 可动态布局的Android抽屉之基础http: ...

  7. 第六章 使用 Bootstrap Typeahead 组件(百度下拉效果)(续)

    官方:http://twitter.github.io/typeahead.js/ 示例:http://twitter.github.io/typeahead.js/examples/(本文展示:Op ...

  8. html、css实现导航栏5种常用下拉效果

    实现的效果:鼠标移入按钮时按钮中的内容就会出现,分别展示不同的出现效果.效果难点:不使用JavaScript,那这个效果的难点就是在于:hover伪类的掌控,以及考验对html的结构掌握. 1. ht ...

  9. iosselect:一个js picker项目,在H5中实现IOS的下拉效果

    iosselect是在webapp下的一个picker组件,可以轻松实现各类选择器效果.比如地区选择 时间选择 日期选择等. 下面是一个地址选择器demo截图,可以访问:http://zhoushen ...

随机推荐

  1. [SharpDevelop]菜单状态更新

    方式一 在Idle方法中更新 void OnApplicationIdle(object sender, EventArgs e) { // Use the Idle event to update ...

  2. HQL的语言

    HQL: 是Hibernate Query Language的缩写 1.HQL查询 特点: 与SQL相似,SQL中的语法基本上都可以直接使用 SQL查询的是表和表中的列而HQL查询的是对象或者对象中的 ...

  3. NSTimer 线程操作

    http://www.jianshu.com/p/0c050af6c5ee 2.NSTimer的创建与撤销必须在同一个线程操作.performSelector的创建与撤销必须在同一个线程操作.

  4. Rman备份的保留策略(retention policy)

    什么是备份的保留策略(retention policy) 保留策略就是指某份备份是否要保留以及保留多久.可以使用configure retention policy命令来创建一个一致的.自动的备份保留 ...

  5. dij最短路优先队列堆的时候,加边

    不能用全局数组d[u]>d[rhs.u]. 这样后面会修改d[u]值然而本来里面的点顺序不该修改,却被修改了. 应该用栈还存进去的临时变量,比如d>rhs.d. 优先队列重载小于号'< ...

  6. FAQ: C++中定义类的对象:用new和不用new有何区别?

    C++用new创建对象和不用new创建对象的区别解析 作者: 字体:[增加 减小] 类型:转载 时间:2013-07-26 我要评论 在C++用new创建对象和不用new创建对象是有区别的,不知你是否 ...

  7. table创建固定表头

    布局:两个div,上部内容将表头复制,高度固定,下部div内部将table设置为margin:-**px; 隐藏掉表头,下部div设置overflow,即可. 代码:

  8. [转]-Dmaven.multiModuleProjectDirectory system propery is not set. 解决方案 适用于myeclipes 和 eclipes

    eclipse中使用maven插件的时候,运行run as maven build的时候报错 -Dmaven.multiModuleProjectDirectory system propery is ...

  9. ofbiz进击 个人遇到的奇葩问题汇总。

    在本人做退货单生成的时候,因为考虑到要控制通过java类方法去调用 service服务可以方便给出提示消息,所以专门新建了一个java类,然后去重新请求request请求,下面为Java类的代码 pu ...

  10. 全局函数VS成员函数

    #include <iostream> using namespace std; class Test { public: Test(int a, int b) { this->a ...