ecshop搜索出现相关商品的效果滑动下拉效果
ecshop搜索栏效果如下
所需要的样式我们可以复制到style.css里:
- /*搜索滑动效果*/
- .Menu {
- position:absolute;
- top:30px;
- left:7px;
- width:150px;
- height:auto;
- z-index:1;
- background:#FFF;
- border:1px solid #000;
- display:none;
- }
- .Menu2 {
- position: absolute;
- left:0;
- top:0;
- width:100%;
- height:auto;
- overflow:hidden;
- z-index:1;
- }
- .Menu2 ul{margin:0;padding:0}
- .Menu2 ul li{width:100%;height:25px;line-height:25px;text-indent:15px;
- border-bottom:1px dashed #ccc;color:#666;cursor:pointer;background:#FFF;
- change:expression(
- this.onmouseover=function(){
- this.style.background="#F2F5EF";
- },
- this.onmouseout=function(){
- this.style.background="";
- }
- )
- }
- input{width:200px}
- .form{width:200px;height:auto;}
- .form div{position:relative;top:0;left:0;margin-bottom:5px}
复制代码
以下代码需要加到输入框普遍 比如page_header.lbi
- <script type="text/javascript">
- function showAndHide(obj,types,text){
- var Layer=window.document.getElementById(obj);
- switch(types){
- case "show":
- if(text!='')
- {
- Layer.style.display="block";
- Ajax.call('search_div.php', 'act=search&text=' + text, changesumResp**e, 'GET', 'JSON');
- }
- break;
- case "hide":
- Layer.style.display="none";
- }
- }
- function getValue(obj,str){
- var input=window.document.getElementById(obj);
- input.value=str;
- }
- function changesumResp**e(res)
- {
- var a='';
- for (var i = 0; i < res.content.length; i++)
- {
- a += "<li onmousedown=getValue('keyword','" + res.content[i].goods_name + "')>" + res.content[i].goods_name + "</li>";
- }
- // alert(a);
- document.getElementById('show_stock').innerHTML = a;
- }
- </script>
复制代码
我们输入框的代码
- <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;"/>
- <div class="Menu" id="List1">
- <div class="Menu2">
- <ul style="padding:0px; margin:0px;" id="show_stock">
- </ul>
- </div>
- </div>
复制代码
ajax请求php的代码
search_div.php
- <?php
- define('IN_ECS', true);
- require(dirname(__FILE__) . '/includes/init.php');
- require(dirname(__FILE__) . '/admin/includes/lib_main.php');
- if($_REQUEST['act'] == 'search'){
- $keywords = json_str_iconv(trim($_GET['text']));
- $sql = "SELECT goods_name,goods_id FROM " . $GLOBALS['ecs']->table('goods')." where goods_name like '%$keywords%'";
- $brand_array = $GLOBALS['db']->getall($sql);
- foreach($brand_array as $ids =>$value)
- {
- $brand_array[$ids]['goods_name'] = sub_str_xaphp($brand_array[$ids]['goods_name'],5);
- }
- make_json_result($brand_array);
- }
- function sub_str_xaphp($str, $length = 0, $append = true)
- {
- $str = trim($str);
- $strlength = strlen($str);
- if ($length == 0 || $length >= $strlength)
- {
- return $str;
- }
- elseif ($length < 0)
- {
- $length = $strlength + $length;
- if ($length < 0)
- {
- $length = $strlength;
- }
- }
- if (function_exists('mb_substr'))
- {
- $newstr = mb_substr($str, 0, $length, EC_CHARSET);
- }
- elseif (function_exists('iconv_substr'))
- {
- $newstr = iconv_substr($str, 0, $length, EC_CHARSET);
- }
- else
- {
- //$newstr = trim_right(substr($str, 0, $length));
- $newstr = substr($str, 0, $length);
- }
- if ($append && $str != $newstr)
- {
- $newstr .= '';
- }
- return $newstr;
- }
- ?>
复制代码
在商品少的情况下 我们之间查询 如果多了,最模板建议修改程序
ecshop搜索出现相关商品的效果滑动下拉效果的更多相关文章
- jQuery手写几个常见的滑动下拉菜单 分分秒秒学习JS
一般的企业网站再我们再实际工作中,有些特效,用jQuery来做,显得极其简单,除非一些大的公司,需要封装自己的类. 今天,我们讲解jQuery入门知识,来写几个简单jQuery滑动下拉菜单.感受一下j ...
- jQuery实现折叠下拉效果
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Android 聊天表情输入、表情翻页带效果、下拉刷新聊天记录
经过一个星期的折腾,最终做完了这个Android 聊天表情输入.表情翻页带效果.下拉刷新聊天记录.这仅仅是一个单独聊天表情的输入,以及聊天的效果实现.由于我没有写server,所以没有两方聊天的效果. ...
- Easy UI combobox实现类似 Select2的效果,下拉带搜索框
一直在开发一个新系统,其中用Easy UI作为前端框架,少不了用 combobox做为一个 下拉控件,它支持 可编辑 模糊本地数据过滤,也可支持 不可编辑 下拉 选择的功能: $('#ID' ).co ...
- MVC身份验证.MVC过滤器.MVC6关键字Task,Async.前端模拟表单验证,提交.自定义匿名集合.Edge导出到Excel.BootstrapTree树状菜单的全选和反选.bootstrap可搜索可多选可全选下拉框
1.MVC身份验证. 有两种方式.一个是传统的所有控制器继承自定义Control,然后再里面用MVC的过滤器拦截.所以每次网站的后台被访问时.就会先走入拦截器.进行前端和后端的验证 一个是利用(MVC ...
- Android抽屉(SlidingDrawer --类似android通知栏下拉效果)
Android抽屉(SlidingDrawer)的实现发 - 红黑联盟http://www.2cto.com/kf/201301/182507.html 可动态布局的Android抽屉之基础http: ...
- 第六章 使用 Bootstrap Typeahead 组件(百度下拉效果)(续)
官方:http://twitter.github.io/typeahead.js/ 示例:http://twitter.github.io/typeahead.js/examples/(本文展示:Op ...
- html、css实现导航栏5种常用下拉效果
实现的效果:鼠标移入按钮时按钮中的内容就会出现,分别展示不同的出现效果.效果难点:不使用JavaScript,那这个效果的难点就是在于:hover伪类的掌控,以及考验对html的结构掌握. 1. ht ...
- iosselect:一个js picker项目,在H5中实现IOS的下拉效果
iosselect是在webapp下的一个picker组件,可以轻松实现各类选择器效果.比如地区选择 时间选择 日期选择等. 下面是一个地址选择器demo截图,可以访问:http://zhoushen ...
随机推荐
- ASP.NET的运行原理与运行机制 如何:为 IIS 7.0 配置 <system.webServer> 节
https://technet.microsoft.com/zh-cn/sysinternals/bb763179.aspx 当一个HTTP请求到服务器并被IIS接收到之后,IIS首先通过客户端请求的 ...
- vmware 共享文件夹 win7 centos6
1. 安装 vmware-tools 1). 右击虚拟机 -- 安装vmware-tools 2). 挂载 mnt /dev/cdrom /mnt 3). yum -y install gcc gcc ...
- 连接sql server数据库的两种方式
class DB { private static SqlConnection conn; public static SqlConnection getConn() { //conn = n ...
- 面向对象 理解 C#复习
面向对象: 是基于万物皆对象这个哲学观点. 所谓的面向对象就是将我们的程序模块化,对象化,把具体事物的特性属性和通过这些属性来实现一些动作的具体方法放到一个类里面 通俗点讲: 一切都是对象 举例: 将 ...
- JavaScript----分层导航 滚动事件
分层导航 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...
- 显示和隐藏Mac下的 隐藏文件
显示:defaults write com.apple.finder AppleShowAllFiles -bool true隐藏:defaults write com.apple.finder Ap ...
- C#: enum
C#的枚举类型跟C++差不多,一般我们将enum设为单个状态,比如enum color_t { RED, BLACK, GREEN}, 只能选择一个 而有的时候枚举可以作为位运算来进行与或运算,比如C ...
- Windows服务安装异常:System.Security.SecurityException: 未找到源,但未能搜索某些或全部事件日志。不可 访问的日志: Security
Windows服务安装异常:System.Security.SecurityException: 未找到源,但未能搜索某些或全部事件日志.不可 访问的日志: Security 2种方法处理: 一.右键 ...
- paper 84:机器学习算法--随机森林
http://www.cnblogs.com/wentingtu/archive/2011/12/13/2286212.html中一些内容 基础内容: 这里只是准备简单谈谈基础的内容,主要参考一下别人 ...
- 《zw版·Halcon-delphi系列原创教程》 水果自动分类脚本(机器学习、人工智能)
<zw版·Halcon-delphi系列原创教程> 水果自动分类脚本(机器学习.人工智能) 前面介绍了超市,流水线,酸奶的自动分类算法,下面再介绍一个水果的自动分类算法. Halcon强大 ...