本文实例讲述了jQuery基于xml格式数据实现模糊查询及分页功能的方法。分享给大家供大家参考,具体如下:

1、此代码只支持xml 格式数据,根据不同需求修改ajax的success方法就ok了
2、此代码只是针对ajax只需一次请求的情况下
String.prototype.trim=function(){return this.replace(/(^\s*)|(\s*$)/g,"");};//解决ie trim问题
(function($) {
/**
* ===============================================================================================================
* ========== 模糊搜索功能 =================================================================================
* ===============================================================================================================
*
* */
$.xml=function(data){//加载xml
var xmlobj=null;
if(window.ActiveXObject){
var xml;
xml = new ActiveXObject("Microsoft.XMLDOM");
xml.async = false;
xml.loadXML(data);
xmlobj=$(xml);
}else{
xmlobj=$(data);
}
return xmlobj;
};
//获取节点
$.getnode=function(key,obj){
var nodevalue=obj.children(key).text();
return nodevalue;
};
$.xmldata=null;
$.jsondata=null;
$.indexdata=null;
$.inputid=null;
$.pagetoolid=null;
$.resultdata=null;
$.pagetotal=1;
$.load=function(url){
$.ajax({
type: "post",
url: url,
dataType: "text",
success:function(data){
$.xmldata=$.xml(data);
var jsonstr='{';
var indexstr="{";
$.xmldata.find("QUERYINFO").find("ROW").each(function(i){
var point=i==0?"":",";
var ZZJGDM=$.getnode("ZZJGDM",$(this));
var JGMC=$.getnode("JGMC",$(this));
var DWLX=$.getnode("DWLX",$(this));
var JGJC=$.getnode("JGJC",$(this));
var JGBH=$.getnode("JGBH",$(this));
var ZCDZ=$.getnode("ZCDZ",$(this));
jsonstr+=point+"'"+JGBH+"':{'ZZJGDM':'"+ZZJGDM+"','JGMC':'"+JGMC+"','JGBH':'"+JGBH+"','JGJC':'"+JGJC+"','ZCDZ':'"+ZCDZ+"','DWLX':'"+DWLX+"'}";
indexstr+=point+"'"+JGMC+"':'"+JGBH+"'";
});
jsonstr+="}";
indexstr+="}";
$.indexdata=eval("("+indexstr+")");
$.jsondata=eval("("+jsonstr+")");
}});
};
$.select=function(obj){//选中结果中的一项时
var id=obj.attr("id");
$("#"+$.inputid).val($.jsondata[id].JGMC);
$("#reg_companysimplename").val($.jsondata[id].JGJC);
$("#reg_companysimplename_form").val($.jsondata[id].JGJC);
$("#reg_companycode").val($.jsondata[id].ZZJGDM==""?"---":$.jsondata[id].ZZJGDM);
$("#reg_companycode_form").val($.jsondata[id].ZZJGDM==""?"---":$.jsondata[id].ZZJGDM);
$("#reg_companytype").val($.jsondata[id].DWLX);
$("#reg_companytype_form").val($.jsondata[id].DWLX);
$("#reg_jgbh").val($.jsondata[id].JGBH);
$("#reg_regaddress").val($.jsondata[id].ZCDZ);
$("#reg_regaddress_form").val($.jsondata[id].ZCDZ);
$("#"+$.inputid).focus();
$("#"+$.inputid).blur();
};
$.fn.search=function(obj){//程序入口
var oldkeyword="";
var id=obj.id;
var url=obj.url;
$.inputid=$(this).attr("id");
if($.xmldata==null){
$.load(url);
}
//========================================键盘事件==========================================
$(this).keyup(function(){
var resultlist=null;
var keywordvalue=$(this).val().trim();
$("#reg_companysimplename").val("");
$("#reg_companycode").val("");
$("#reg_companytype").val("");
if(keywordvalue==""||oldkeyword==keywordvalue){//解决ie 的keyup 事件异常
if(keywordvalue==""){
$("#"+id+" ul").parent().hide();
}
return;
}else{
oldkeyword=keywordvalue;
}
var jsonstr='{';
var rownum=0,pagesize=10,num=0;
$.pagetotal=1;
$.indexsearch($.indexdata,keywordvalue);
resultlist=$.indexsearch($.indexdata,keywordvalue);
var ids="[";
for(var i in resultlist){//给查询结果分页
var point=$.pagetotal==1?"":",";
rownum++;
if(rownum>=pagesize&&rownum%pagesize==0||resultlist.length==rownum){
ids+=","+"'"+resultlist[i]+"']";
jsonstr+=point+"'"+$.pagetotal+"':"+ids;
ids="[";
num=0;
if(rownum%pagesize==0){
$.pagetotal++;
}
}else{
point=num==0?"":",";
ids+=point+"'"+resultlist[i]+"'";
num++;
}
}
jsonstr+="}";
$.resultdata=eval("("+jsonstr+")");
//初始化结果列表
if(rownum==0)return;
var pagenum=1;
$.pageto(pagenum,$.resultdata,$("#"+id+" ul"));
if($.pagetotal>1){
$.pagetool.createpagetool($.pagetotal);
$.pagetool.pageto(pagenum,$.pagetotal);
$("#pagetool span[pagenum='1']").css("backgroundColor",'lightblue');
}else{
$("#pagetool").html("");
}
$("#pagetool .num").click(function(){
pagenum=eval($(this).text());
$("#pagetool span").css("backgroundColor",'white');
$(this).css("backgroundColor",'lightblue');
$.pageto(pagenum,$.resultdata,$("#"+id+" ul"));
});
$("#pagetool .up").click(function(){
pagenum--;
if(pagenum!=0){
$("#pagetool span").css("backgroundColor",'white');
$("#pagetool span[pagenum='"+pagenum+"']").css("backgroundColor",'lightblue');
$.pageto(pagenum,$.resultdata,$("#"+id+" ul"));
$.pagetool.pageto(pagenum);
}else{
pagenum++;
}
});
$("#pagetool .down").click(function(){
pagenum++;
if(pagenum<=$.pagetotal){
$("#pagetool span").css("backgroundColor",'white');
$("#pagetool span[pagenum='"+pagenum+"']").css("backgroundColor",'lightblue');
$.pageto(pagenum,$.resultdata,$("#"+id+" ul"));
$.pagetool.pageto(pagenum);
}else{
pagenum--;
}
});
});
};
//工具栏分页
$.pagetool = {
createpagetool : function(pagetotal) {
var html = "<span class='up'>up</span>";
var pagetoolpagenum=1;
for (var i = 1; i <= pagetotal; i++) {
if(i%5==1&&i>5){
pagetoolpagenum++;
}
html += "<span pagenum='"+i+"' i='" +pagetoolpagenum + "' class='num'>" + i
+ "</span>";
}
html += "<span class='down'>down</span>";
$("#pagetool").html(html);
},
pageto : function(pagenum,pagetotal) {
var pagetoolpagenum=1;
if(pagenum>5){
pagetoolpagenum=Math.ceil(pagenum/5);
}
$("#pagetool span").hide();
$("#pagetool span:first").show();
$("#pagetool span[i='"+pagetoolpagenum+"']").show();
$("#pagetool span:last").show();
}
};
//模糊搜索
$.indexsearch=function(indexdata,keyword){
var resultids=new Array();
for (var key in $.indexdata){
if(key.indexOf(keyword)!=-1)
resultids.push($.indexdata[key]);
}
return resultids;
};
//跳页程序
$.pageto=function(pagenum,data,obj){
var list=data[pagenum];
var html="";
obj.html(html);
obj.parent().show();
$(list).each(function(i){
try{
html+='<li id="'+list[i]+'" >'+$.jsondata[list[i]].JGMC+'</li>';
}catch(e){}
});
obj.html(html);
obj.find("li").bind({//结果集的点击事件
"click":function(){
$.select($(this));
obj.parent().hide();
obj.parent().find("#pagetool").html("");
},
"mouseover":function(){//结果集的鼠标悬浮事件
$(this).parent().find("li").css("backgroundColor","white");
$(this).css("backgroundColor","lightblue");
}
});
};
}(jQuery));
在页面中调用
<div class="item_input fl">
<input id="reg_companyname" autocomplete="off" type="text" class="text" name="DWBM_SV"/>
<div id="resultlist" class="hidden" style="width:300px;margin-top: 1px;display:none;">
<ul></ul>
<div class="pagetool" id="pagetool"></div>
</div>
</div>
<script>
$("#reg_companyname").search({"id":"resultlist","url":"/getcompany.go"});
</script>
运行效果 (不同的效果需要不同的样式)
PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:
在线XML/JSON互相转换工具:
http://tools./code/xmljson
在线格式化XML/在线压缩XML:
http://tools./code/xmlformat
XML在线压缩/格式化工具:
http://tools./code/xml_format_compress
XML代码在线格式化美化工具:
http://tools./code/xmlcodeformat
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery操作xml技巧总结》、《jquery中Ajax用法总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery拖拽特效与技巧总结》、《jQuery表格(table)操作技巧汇总》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
# jQuery
# xml格式
# 数据
# 模糊查询
# 分页
# jquery zTree异步加载、模糊搜索简单实例分享
# jquery ztree实现模糊搜索功能
# jQuery实现id模糊查询的小例子
# jquery easyui combobox模糊过滤(示例代码)
# jQuery实现select模糊查询(反射机制)
# jQuery简单实现的HTML页面文本框模糊匹配查询功能完整示例
# jQuery实现模糊查询的方法分析
# jQuery实现模糊搜索功能的方法分析
# 相关内容
# 鼠标
# 只需
# 感兴趣
# 给大家
# 更多关于
# 所述
# 查询结果
# 几款
# 程序设计
# 搜索功能
# 转换工具
# 再为
# 拖拽
# 情况下
# 操作技巧
# 加载
# 选择器
# 讲述了
相关文章:
开源网站制作软件,开源网站什么意思?
太原网站制作公司有哪些,网约车营运证查询官网?
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
如何选择高效响应式自助建站源码系统?
网站制作网站,深圳做网站哪家比较好?
音乐网站服务器如何优化API响应速度?
广平建站公司哪家专业可靠?如何选择?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
全景视频制作网站有哪些,全景图怎么做成网页?
网站制作知乎推荐,想做自己的网站用什么工具比较好?
如何在阿里云服务器自主搭建网站?
,柠檬视频怎样兑换vip?
音响网站制作视频教程,隆霸音响官方网站?
建站主机选购指南:核心配置与性价比推荐解析
如何在宝塔面板中创建新站点?
如何通过FTP服务器快速搭建网站?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
,如何利用word制作宣传手册?
内部网站制作流程,如何建立公司内部网站?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何高效配置香港服务器实现快速建站?
网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?
建设网站制作价格,怎样建立自己的公司网站?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
如何确保西部建站助手FTP传输的安全性?
利用JavaScript实现拖拽改变元素大小
高端网站建设与定制开发一站式解决方案 中企动力
制作国外网站的软件,国外有哪些比较优质的网站推荐?
建站主机类型有哪些?如何正确选型
安云自助建站系统如何快速提升SEO排名?
如何通过虚拟主机快速完成网站搭建?
建站主机是否等同于虚拟主机?
建站之星如何快速更换网站模板?
如何通过虚拟机搭建网站?详细步骤解析
建站主机系统SEO优化与智能配置核心关键词操作指南
建站主机核心功能解析:服务器选择与网站搭建流程指南
建站之星ASP如何实现CMS高效搭建与安全管理?
如何用美橙互联一键搭建多站合一网站?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
,网页ppt怎么弄成自己的ppt?
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
如何在IIS管理器中快速创建并配置网站?
如何快速重置建站主机并恢复默认配置?
常州企业建站如何选择最佳模板?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
建站主机如何选?性能与价格怎样平衡?
如何选择PHP开源工具快速搭建网站?
个人摄影网站制作流程,摄影爱好者都去什么网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。