JS实现关键字搜索时的相关下拉字段效果


Posted in Javascript onAugust 05, 2014
<!DOCTYPE html> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=GBK" /> 
<title>Hello World</title> 
<link href="style.css" rel="external nofollow" rel="stylesheet" type="text/css"> 
 
<script type="text/javascript"> 
  sources= new Array("www.sina.com","www.baidu.com","www.google.com","www.sina.org","www.baidu.ogr.cn"); 
  tabinfo = ""; 
  flag = new Array(sources.length); 
  for(var i=0;i<flag.length;i++) 
    flag[i] = false ; 
   
  function immediately(){ 
     
    var element = document.getElementById("i1"); 
    if("\v"=="v") { 
      element.onpropertychange = webChange; 
    }else{ 
      element.addEventListener("input",webChange,false); 
    } 
    function webChange(){ 
      var tab = document.all("dl1"); 
      for(var i=0;i<flag.length;i++) 
        flag[i] = false ;//重新初始化 
      if(element.value){ 
        var content = document.getElementById("i1").value; 
        for(var i = 0 ;i < sources.length ; i ++){ 
          if(sources[i].indexOf(content) != -1){ 
            flag[i] = true;    
          } 
        } 
        for(var j=0;j<flag.length;j++){ 
           
          if(flag[j]){//sources[j]有与文本框文字相同的内容 
            if(tab.rows.length>0){ 
              for(var k=0;k<tab.rows.length;k++) 
                if(tab.rows[k].cells[0].innerText.indexOf(content) == -1) 
                  tab.deleteRow(k); 
            } 
            for(var k=0;k<tab.rows.length;k++){ 
              tabinfo += tab.rows[k].cells[0].innerText; 
            }   
            if(tabinfo.indexOf(sources[j]) == -1){  
              nrow = tab.insertRow(0); 
              newcell = nrow.insertCell(); 
              newcell.innerHTML = sources[j]  
            } 
            tabinfo = ""; 
          } 
           
           
        } 
      } 
    } 
  } 
 
</script> 
<script language="javascript"> 
  var lastObj=null;  
  function backBlack(){ 
    event.srcElement.style.background="gray"; 
    forceBackC6(); 
    if(event.srcElement.tagName=="TD"){ 
      lastObj=event.srcElement; 
    } 
    fillData(); 
  } 
  function backC6(){ 
    event.srcElement.style.background="#CCCCCC"; 
  } 
  function forceBackC6(){ 
   if(lastObj!=null) 
    lastObj.style.background="#F8F8FF"; 
  } 
 
 
  function fillData(){ 
    if(lastObj.innerHTML!=null) 
     document.all.i1.value=lastObj.innerHTML;  
  } 
   
  function init(){ 
    Layer1.style.top=i1.offsetTop+40; 
    Layer1.style.left=i1.offsetLeft; 
    Layer1.style.visibility="visible"; 
  } 
  function hideBelow(){ 
    Layer1.style.visibility="hidden"; 
  } 
</script> 
 
</head> 
<body> 
<input type="text" id="i1" style="height:20px" onFocus="init()" onBlur="hideBelow()" /> 
<script type="text/javascript"> 
immediately(); 
</script> 
<div id="Layer1"> 
 <table id="dl1" class="midHead" cellspacing="0" onMouseOut="backC6()" onMouseOver="backBlack()" border="0" > 
   
 </table> 
</div> 
 
<br> 
 
</body> 
</html>
Javascript 相关文章推荐
js 鼠标点击事件及其它捕获
Jun 04 Javascript
js中的string.format函数代码
Aug 11 Javascript
JavaScript内核之基本概念
Oct 21 Javascript
深入理解JavaScript系列(10) JavaScript核心(晋级高手必读篇)
Jan 15 Javascript
js动态添加onload、onresize、onscroll事件(另类方法)
Dec 26 Javascript
JavaScript模版引擎的基本实现方法浅析
Feb 15 Javascript
gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点
Feb 21 Javascript
js动态获取子复选项并设计全选及提交的实现方法
Jun 24 Javascript
JavaScript数据结构链表知识详解
Nov 21 Javascript
JavaScript &amp; jQuery完美判断图片是否加载完毕
Jan 08 Javascript
详解webpack+angular2开发环境搭建
Jun 28 Javascript
springboot+vue实现文件上传下载
Nov 17 Vue.js
js实现点击后将文字或图片复制到剪贴板的方法
Aug 04 #Javascript
JavaScript中的函数重载深入理解
Aug 04 #Javascript
window.print打印指定div指定网页指定区域的方法
Aug 04 #Javascript
jQuery 删除或是清空某个HTML元素示例
Aug 04 #Javascript
js实现正方形颜色从下往上升的效果
Aug 04 #Javascript
与Math.pow 相反的函数使用介绍
Aug 04 #Javascript
简单易用的倒计时js代码
Aug 04 #Javascript
You might like
php imagecreatetruecolor 创建高清和透明图片代码小结
2010/05/15 PHP
解析mysql 表中的碎片产生原因以及清理
2013/06/22 PHP
ThinkPHP3.1新特性之多数据库操作更加完善
2014/06/19 PHP
ThinkPHP登录功能的实现方法
2014/08/20 PHP
关于onScroll事件在IE6下每次滚动触发三次bug说明
2011/09/21 Javascript
jQuery不间断滚动效果(模拟百度新闻支持文字/图片/垂直滚动)
2013/02/05 Javascript
window.location不跳转的问题解决方法
2014/04/17 Javascript
javascript实现瀑布流动态加载图片原理
2016/08/12 Javascript
详解jQuery事件
2017/01/13 Javascript
微信小程序 wx.login解密出现乱码的问题解决办法
2017/03/10 Javascript
jQuery插件HighCharts绘制2D饼图效果示例【附demo源码下载】
2017/03/21 jQuery
JavaScript数据结构之二叉查找树的定义与表示方法
2017/04/12 Javascript
在vue中使用css modules替代scroped的方法
2018/03/10 Javascript
基于JS实现table导出Excel并保留样式
2020/05/19 Javascript
[37:47]IG vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
Python将文本去空格并保存到txt文件中的实例
2018/07/24 Python
对python中词典的values值的修改或新增KEY详解
2019/01/20 Python
python接口自动化(十六)--参数关联接口后传(详解)
2019/04/16 Python
浅析python内置模块collections
2019/11/15 Python
Python如何用filter函数筛选数据
2020/03/05 Python
Python要求O(n)复杂度求无序列表中第K的大元素实例
2020/04/02 Python
基于python图像处理API的使用示例
2020/04/03 Python
PyCharm中如何直接使用Anaconda已安装的库
2020/05/28 Python
希腊香水和化妆品购物网站:Parfimo.gr
2019/10/03 全球购物
什么是Deployment descriptors;都有什么类型的部署描述符
2015/07/28 面试题
学校司机岗位职责
2013/11/14 职场文书
社区端午节活动方案
2014/01/28 职场文书
《花的勇气》教后反思
2014/02/12 职场文书
五年级学生评语
2014/04/22 职场文书
机关作风建设自查报告及整改措施
2014/10/21 职场文书
小学数学教师研修日志
2015/11/13 职场文书
创业计划书之蛋糕店
2019/08/29 职场文书
2019朋友新婚祝福语精选
2019/10/10 职场文书
解决python3安装pandas出错的问题
2021/05/20 Python
pytorch中[..., 0]的用法说明
2021/05/20 Python
Python 使用 Frame tkraise() 方法在 Tkinter 应用程序中的Frame之间切换
2022/04/24 Python