suggest ajax,高仿google suggest ajax示例

2023-11-19

///搜索提示框/

var obj_div;     //提示层对象

var obj_input;     //输入框对象

var main_delay;     //判断值变化延迟对象

var ajax_delay;     //ajax延迟搜索对象

var updown_delay;    //方向键延迟对象

var ajax_xmlhttp;    //ajax对象

var div_word=null;    //当前提示层对应的搜索值

var li_num=-1;     //伪光标位置,提示层被选中的li序号,从0开始

var li_down=-1;     //鼠标按下提示层的序号

var value_ed='';    //输入框延迟前的值

var value_ing='';    //输入框当前的值

var value_unexit='';   //搜索过没有结果的值开头

var updown_run=false;   //允许方向键上下

var ajax_run=false;    //true为正常进程,false停止ajax

var ajax_run_ing=false;   //true正在运行,false空闲

var input_focus=false;   //文本框焦点

var url='ajax.asp';    //后台地址**********************************************************

var time_delayajax=300;   //搜索延迟**********************************************************

var time_delayupdown=100;  //方向键延迟********************************************************

var $=function(Fun_id){

return document.getElementById(Fun_id);

}

try{

ajax_xmlhttp= new ActiveXObject('Msxml2.XMLHTTP');

}catch(e){

try{

ajax_xmlhttp= new ActiveXObject('Microsoft.XMLHTTP');

}catch(e){

try{

ajax_xmlhttp= new XMLHttpRequest();

}catch(e){ajax_xmlhttp=null;}

}

}

创建提示层

function createajaxdiv(){

var create_div = document.createElement('div');

create_div.type = 'div';

var promptdiv = document.body.appendChild(create_div);

promptdiv.className = 'ajaxsearch';

obj_div=promptdiv;

}

设置提示层位置

function removediv(){

if(!obj_div || !obj_input)return false;

if(obj_div.style.display=='none')return false;

var obj=obj_input;

var xtop=0;

var xleft=0;

while(obj){

xtop += obj['offsetTop'];

xleft += obj['offsetLeft'];

obj = obj.offsetParent;

}

obj_div.style.left = xleft + 'px';

obj_div.style.top = (xtop + 20) + 'px';    //20差不多是输入框的高度,请根据实际情况调整************************************************************8

li_down=-1;

}

隐藏提示层

function hideajaxdiv(){

obj_div.style.display='none';

li_down=-1;

}

设置被选

css样式

function setlistyle(){

for(var i=0;i

obj_div.firstChild.childNodes[i].id='';

}

if(li_num!=-1)obj_div.firstChild.childNodes[li_num].id='liseleted';

}

鼠标经过提示层

function overli(Fun_seletedlinum){

if(li_num==-1)value_ing=obj_input.value;

li_num=Fun_seletedlinum;

setlistyle();

}

鼠标拖动提示层

function moveli(){

if(window.getSelection){

setfocus();

window.getSelection().removeAllRanges();

}else{

document.selection.empty();

setfocus();

}

}

鼠标按下提示层

function downli(Fun_seletedlinum){

if(!obj_input)return false;

li_down=Fun_seletedlinum;

input_focus=true;

}

鼠标弹起提示层

function upli(Fun_seletedlinum,Fun_event){

if(!obj_input)return false;

if(Fun_event.button==2){li_down=-1;return}

if(li_down!=Fun_seletedlinum){

li_down=-1;

return false;

}

clearTimeout(ajax_delay);

clearTimeout(updown_delay);

updown_run=true;

ajax_run=false;

ajax_run_ing=false;

li_num=-1;

div_word=null;

value_ed=obj_div.firstChild.childNodes[Fun_seletedlinum].childNodes[1].nodeValue;

obj_input.value=value_ed;

value_ing=value_ed;

hideajaxdiv();

obj_div.innerHTML='';

}

设置文本框获取焦点///

function setfocus(){

if(window.event){

var r = obj_input.createTextRange();

r.moveStart('character',obj_input.value.length);

r.collapse(true);

r.select();

}else{

obj_input.selectionStart=obj_input.value.length;

obj_input.focus();

}

}

文本框失去焦点

function blurdeal(){

if(input_focus==true){

setfocus();

setTimeout('setfocus()');

return false;

}

updown_run=false;

ajax_run=false;

ajax_run_ing=false;

clearInterval(main_delay);

clearTimeout(ajax_delay);

clearTimeout(updown_delay);

hideajaxdiv();

if(value_ed!=obj_input.value)obj_div.innerHTML='';

}

文本框获取焦点

function focusdeal(Fun_event){

if(!obj_div)createajaxdiv();

if(input_focus==true){

input_focus=false;

return false;

}

var obj=((window.event)?Fun_event.srcElement:Fun_event.target);

if(obj.type!='text')return false;

updown_run=true;

ajax_run=true;

ajax_run_ing=false;

if(obj_input==obj && value_ed==obj.value && obj_div.innerHTML!=''){

obj_div.style.display='block';

removediv();

}else{

obj_input=obj;

value_ed=obj.value;

value_ing=obj.value;

value_unexit='';

li_num=-1;

li_down=-1;

div_word=null;

obj_div.innerHTML='';

removediv();

}

main_delay=setInterval('mainajax()',10);

}

主函数

function mainajax(){

if(value_ed==obj_input.value)return false;

if(value_unexit!='' && (obj_input.value).indexOf(value_unexit)==0){hideajaxdiv();obj_div.innerHTML='';return false;}

if(value_ed!=obj_input.value && ajax_run_ing==false){

ajax_run=true;

value_ed=obj_input.value;

clearTimeout(ajax_delay);

if(obj_input.value!=''){

ajax_delay=setTimeout('getsearch();',time_delayajax);

}else{

hideajaxdiv();

obj_div.innerHTML='';

ajax_run=false;

return false;

}

}

}

获取搜索内容

function getsearch(){

var temp_value=obj_input.value;

if(ajax_xmlhttp==null){

return false;

}else if(ajax_xmlhttp.readyState!=0){

ajax_xmlhttp.abort();

ajax_run_ing=false;

}

ajax_xmlhttp.onreadystatechange=function(){

if(ajax_run==false){ajax_xmlhttp.abort();ajax_run_ing=false;return false;}

if(ajax_xmlhttp.readyState==4){

obj_div.innerHTML='';

if(ajax_xmlhttp.status==200 || ajax_xmlhttp.status==304){

var contant=ajax_xmlhttp.responseText;

if(contant!='' && ajax_run==true){

div_word=temp_value;

obj_div.innerHTML=resetcontant(contant);

obj_div.style.display='block';

removediv();removediv();

}else{

hideajaxdiv();

}

updown_run=true;

ajax_run_ing=false;

li_num=-1;

if(contant=='')value_unexit=temp_value;

}

}

}

ajax_xmlhttp.open('post',url,true);

ajax_xmlhttp.setRequestHeader('Content-type','application/x-www-form-urlencoded');

ajax_run_ing=true;

ajax_xmlhttp.send('sift_value='+escape(temp_value)); //提交到后台的值*****************************************

}

内容重组///

function resetcontant(Fun_contant){

if(Fun_contant==null || Fun_contant=='')return '';

var a=Fun_contant.substring(1,Fun_contant.length-1);

if(Fun_contant==null || Fun_contant=='')return '';

var b=a.split('''');

var c;

var d;

d='

  • ';

for(var i in b){

c=b[i].split(',');

//***************************************************************

d=d+'

约'+c[1]+'结果'+c[0]+'';

//***************************************************************

}

d=d+'

关闭'

d=d+'';

return d;

}

键盘事件

function keydowndeal(Fun_event){

var keyc=((window.event)?Fun_event.keyCode:Fun_event.which);

if(keyc==13){hideajaxdiv();return false;}

if(keyc==27){

if(obj_div.style.display=='block' && li_num>-1)value_ed=obj_input.value=value_ing;

hideajaxdiv();

return false;

}

if(keyc==40 || keyc==38){

if(div_word==obj_input.value && obj_div.style.display=='none' && obj_div.innerHTML!=''){

obj_div.style.display='block';

removediv();

return false;

}

if(li_num==-1){

if(div_word!=obj_input.value)return false;

}else{

if(div_word!=value_ing)return false;

}

if(updown_run==false || ajax_run_ing==true || obj_div.style.display=='none')return false;

updown_delay=setTimeout('updownli('+keyc+')',time_delayupdown);

updown_run=false;

}

}

方向键移动li

function updownli(Fun_key){

if(!obj_div){return false;}

updown_run=true;

if(li_num==-1){

if(div_word!=obj_input.value){hideajaxdiv();obj_div.innerHTML='';li_num=-1;return false;}

}else{

if(div_word!=value_ing){hideajaxdiv();obj_div.innerHTML='';li_num=-1;return false;}

}

if(updown_run==false)return false;

if(li_num==-1)value_ing=value_ed;

if(Fun_key==40){

if(li_num

li_num++;

}else{

li_num=-1;

}

}

if(Fun_key==38){

if(li_num>=0){

li_num--;

}else{

li_num=obj_div.firstChild.childNodes.length-2;

}

}

if(li_num!=-1){

value_ed=obj_input.value=obj_div.firstChild.childNodes[li_num].childNodes[1].nodeValue;

}else{

value_ed=obj_input.value=value_ing;

}

setlistyle();

}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

suggest ajax,高仿google suggest ajax示例 的相关文章

  • 第48讲 第49讲--动态定位单元格区域1-End属性、动态定位单元格区域2、3-Currentregion UsedRange

    1 单元格区域 EntireRow返回该区域所在的整行对象单元格区域 EntireColumn返回该区域所在的整列 返回单元格所在的整行与整列 返回单元格对象 EntireRow 与EntireColumn Sub 整行与整列 Range
  • 制作一个“生日快乐”App,来自程序员的生日礼物~

    点击上方 码农的后花园 选择 星标 公众号 精选文章 第一时间送达 之前给大家制作了一个来自程序员的表白神器 本期带大家做一个 生日快乐 App 来自程序员的生日礼物 不要再说程序员不懂浪漫咯 往期精彩 Android App 开发的三种姿
  • hibernate 异常

    1 异常 org hibernate AnnotationException No identifier specified for entity异常 entity类是必须要主键的 否则就会报出这个异常 Id GeneratedValue
  • 布隆过滤器的简单介绍与实例(Bloom Filter)

    转载https blog csdn net leeafay article details 78681534 布隆在1970年提出了布隆过滤器 Bloom Filter 是一个很长的二进制向量 可以想象成一个序列 和一系列随机映射函数 ha
  • TensorFlow.js - 使用 CNN(卷积神经网络) 识别手写数字

    目录 index html data js script js 备注 参考文献 index html
  • ChatGPT是免费的吗?

    ChatGPT并非由单个实体或公司所拥有和控制 而是由OpenAI推出和维护的人工智能技术 其可以被免费使用 OpenAI提供API服务和开发者工具 可以让开发者和用户将ChatGPT集成到自己的应用程序中 虽然使用ChatGPT本身是免费
  • Nginx配置整合:基本概念、命令、反向代理、负载均衡、动静分离、高可用

    一 基本概念 1 什么是Nginx Nginx是一个高性能的HTTP和反向代理服务器 也是一个IMAP POP3 SMTP代理server 其特点是占有内存少 并发能力强 其并发能力确实在同类型的网页server中表现较好 http服务器
  • 飞腾D2000 UOS下安装KVM虚拟机

    其他的和x86环境都差不多 开了开发者模式后 virt manager qemu efi aarch64 qemu system 几个包补齐 启动libvirtd服务 查看日志 报以下日志 4月 09 21 13 34 actionchen
  • JAVA虚拟机灵魂之问:Xmx和Xms不一致对虚拟机性能有何影响

    使用jvisualVM查看idea进程 发现其关于堆大小的参数设置如下 并发现随着idea加载项目 其实际使用的内存会自动增大 加载项目前和加载项目后 堆大小是不一样的 有一个大幅提升的阶段 随着所需要的内存的增多 虚拟机会多次向操作系统申
  • FreeBSD配置ip和开启SSH

    首先ifconfig a 看下网卡名称 然后vi etc rc conf 我先贴下我的图吧 主要是 ifconfig le0这个的 set ip ifconfig le0 inet 192 168 1 213 netmask 255 255
  • openEuler操作系统及其安装使用

    文章目录 1 目标 2 openEuler操作系统介绍 2 1 发布件 2 2 最小硬件要求 2 3 硬件兼容性 2 4 关键特性 2 4 1 openEuler 22 03 LTS基于 Linux Kernel 5 10 内核构建 在进程
  • obsidian上手使用

    前言 我之前一直使用的是typora typora付费后就没有使用过了 后面就一直找markdown编辑器 在一次网课中我发现了老师用的网页富文本编辑器非常不错 这样我认识了语雀 语雀的文本编辑体验确实非常的不错 还可以在笔记里添加思维导图
  • 使用 SpringBoot 访问 MySQL 数据库

    一 目标 创建一个 MySQL 数据库 构建一个 Spring 应用程序 并将其连接到新创建的数据库 二 准备工作 1 最喜欢的文本编辑器或 IDE 2 Java 17或更高版本 3 Gradle 7 5 或Maven 3 5 三 初始化项
  • 使用Python制作酷炫的二维码

    参考 https www cnblogs com zhuwjwh p 11401312 html 制作动图二维码只需要原始图像是动图就可以哦 制作动图可以参考我之前的博客
  • 量化编程环境python库安装包

    必装工具包 1 ccxt conda没有 2 pandas 3 pathos 并发计算 conda没有 4 websocket 获取实时数据 conda没有 5 ntplib 用于时间校对 conda没有 6 cryptography 加密
  • Qt中 gui 模块和 widgets 模块的区别

    作者 billy 版权声明 著作权归作者所有 商业转载请联系作者获得授权 非商业转载请注明出处 简述 在Qt5下 QWidget系列从QtGui中被剥离出去 成为单独的QtWidget模块 随着Qt Quick2的引入 QtDeclarat
  • 【JavaScript】js继承

    es6 extends继承 原型式继承 构造函数继承 组合式继承 一 es6 extends继承 scala复制代码 class Child extends Parent constructor super this name 张三 let
  • Java课程设计之学习成绩管理系统

    package System import java awt import java awt event import java io import javax swing import javax swing table Abstract
  • JavaScript的slice()方法最详解

    JavaScript slice 方法怎么用 最详尽最易懂的讲解 1 JavaScript slice 方法的定义 slice 方法可提取字符串的某个部分 并以新的字符串返回被提取的部分 2 1 JavaScript slice 方法的语法

随机推荐

  • 基于LLMs的多模态大模型(Flamingo, BLIP-2,KOSMOS-1,ScienceQA)

    前一篇博客已经整理了不训练视觉模型的文章们 基于LLMs的多模态大模型 Visual ChatGPT PICa MM REACT MAGIC 本篇文章将介绍一些需要训练视觉编码器来适配多模态大模型的工作们 这也是目前最为流行的研究思路 其实
  • 2022 如何在 GitHub 上搭建个人网站(github.io)

    前言 目前 想要搭建自己的项目演示 又想要免费的服务 这时就可以使用 GitHub 提供的免费Pages服务 github io 前置 有GitHub账号 熟练使用git版本管理 成果展示 步骤 第一步 新建仓库 在GitHub上 创建一个
  • 下一步准备给自研引擎换皮

    抄完osg osgearth 鬼火引擎最低版本 以及ogre的大部分后 看到消息处理都通过窗口 突然顿悟 引擎都是类似的 下一步给自研引擎换皮 全换成ogre的皮 渲染流程类似osg的 多线程渲染 无非就是在哪个线程wglMakeCurre
  • 云原生热门话题|什么是可观测性-Observability

    code杂坛 关注一线大厂 互联网时讯 各技术栈 产品 开源社区 等最新讯息 1 可观测性引入 可观测性 术语源于几十年前的控制理论 在许多实际问题中 控制系统的状态变量不是由直接测量得到的 而是通过某种观测方法得到的 由某种观测系统所得到
  • 深大自考本科所需课程

    自考本科需要通过课程 网络经济与企业管理 数据结构导论 运筹学基础 信息资源管理 中国近代史纲要 计算机原理 马克思主义基本原理概论 数据库系统原理 管理经济学 软件开发工具 C 程序设计 英语2 操作系统概论 管理信息系统 计算机网络原理
  • 【OpenCV学习笔记】【编程实例】五 (霍夫圆检测)

    GetCircle cpp 定义控制台应用程序的入口点 圆形检测代码demo 载入数张包含各种形状的图片 检测出其中的圆形 include cv h include highgui h include
  • 排队论(Queuing Theory)

    目录 简介 一 基本概念 1 1 排队过程的一般表示 1 2 排队系统的组成和特征 1 2 1 输入过程 1 2 2 排队规则 1 2 3 服务过程 1 3 排队模型的符号表示 1 4 排队系统的运行指标 二 输入过程与服务时间的分布 2
  • 【MySQL】—— 在windows下的MySQL安装与配置

    更新日志 2020 11 13 文章发布 说明 本文地址 MySQL 在windows下的MySQL安装与配置 https blog csdn net maixiaochai article details 109676520 关于 Mai
  • 2FSK调制解调实验

    一 2FSK原理 频移键控是利用载波的频率变化来传递数字信息 数字频率调制是数据通信中使用较 早的一种通信方式 由于这种调制解调方式容易实现 抗噪声和抗衰减性能较强 因此在 中低速数字通信系统中得到了较为广泛的应用 在2FSK中 载波的频率
  • 树与二叉树(二叉树的表示,性质,遍历,还原)

    1 基本术语 A 或B 是I的祖先 I是A 或B 的子孙 D是I的双亲 I是D的孩子 节点的孩子个数称为节点的度 树中节点的最大度数称为树的度 度大于0的节点称为分支节点 度等于0的节点称为叶节点 定义树根为第一层 则 树的深度 高度 为5
  • 数据库开发三:JDBC数据库开发入门三(PrepareStatement的使用及预处理原理)

    目录 一PrepareStatement使用 二预处理原理 文章相关视频出处 https developer aliyun com lesson 1694 13598 spm 5176 10731542 0 0 4a023fdbjxoV5w
  • Java准确获取Word/Excel/PPT/PDF的页数(附Word页数读不准的处理办法)

    Java准确获取Word Excel PPT PDF的页数 附Word页数读不准的处理办法 1 需求背景 2 环境准备工作 2 1 JACOB介绍及安装 2 2 Microsoft Office Word的设置 3 代码 3 1 代码示例
  • Python实现“鸟脸识别”系统,看看什么鸟最贪吃~ 初学者也能学会

    梦晨 发自 凹非寺 量子位 报道 公众号 QbitAI 网友cldud1245是一个鸟类爱好者 以下简称喂鸟哥 最近打算自学Python 拥有其他语言编程经验的他 可不打算按部就班从Hello World做起 一上来就挑战图像识别 他用一个
  • 数学建模的六个步骤

    一 模型准备 了解问题的实际背景 明确其实际意义 掌握对象的各种信息 以数学思路来解释问题的精髓 数学思路贯彻问题的全过程 进而用数学语言来描述问题 要求符合数学理论 符合数学习惯 清晰准确 理解实际问题后 搜集资料 快速阅读和理解参考文献
  • 神经网络编程技巧(一):两个矩阵相乘报错,np.random.randn(5,)不是矩阵,np.random.randn(5,1)才能得到1*5的矩阵,np.dot()函数

    np dot函数主要用于向量的点积和矩阵的乘法 格式如下np dot a b 其中a b均为n维向量 具体例子参考下面的代码及其结果 在神经网络中经常使用这个函数 能够节约大量的时间 原来复杂的公式在编程时只需要这一行代码即可实现 在编写p
  • Qt实现Excel读写

    QtXlsx 是 第三方的Qt库 为Qt程序提供读写Excel的接口 不单单是Microsoft Excel 它可以用于任何Qt支持的平台 相比Qt官方的QAxObject QtXlsx提供的接口封装层次更高 使用更加简便 github主页
  • LeetCode 933. 最近的请求次数

    写一个 RecentCounter 类来计算特定时间范围内最近的请求 请你实现 RecentCounter 类 RecentCounter 初始化计数器 请求数为 0 int ping int t 在时间 t 添加一个新请求 其中 t 表示
  • 存储计划:自动kill掉死锁进程id

    CREATE PROCEDURE dbo sp who lock1116 AS exec sp who lock1116 begin declare spid int bl int intTransactionCountOnEntry in
  • 结构体封装(C语言)

    转自 http blog jobbole com 57822 我也不理会失不失落 只是对结构体封装技术感兴趣 目录 1 谁该阅读这篇文章 2 我为什么写这篇文章 3 对齐要求 4 填充 5 结构体对齐及填充 6 结构体重排序 7 难以处理的
  • suggest ajax,高仿google suggest ajax示例

    搜索提示框 var obj div 提示层对象 var obj input 输入框对象 var main delay 判断值变化延迟对象 var ajax delay ajax延迟搜索对象 var updown delay 方向键延迟对象