浅沫记忆 发表于 2021-10-23 21:08:52

JSP + ajax实现输入框自动补全功能 实例代码

下面是我用ajax实现的输入框自动补全功能,数据库数据很少,大体模仿出了百度首页的提示功能,当然,人家百度的东西不只是这么简单的!先看运行效果:

index.jsp(包含主要的js代码)

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme() + "://"
            + request.getServerName() + ":" + request.getServerPort()
            + path + "/";
%>
   
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="https://www.w3.org/1999/xhtml">
<head>
<title>查找</title>
<script type="text/javascript">
    function mSift_SeekTp(oObj, nDire) {
      var nPosition = null;
      if (oObj.getBoundingClientRect && !document.all) {
            var oDc = document.documentElement;
            switch (nDire) {
            case 0:
                return oObj.getBoundingClientRect().top + oDc.scrollTop;
            case 1:
                return oObj.getBoundingClientRect().right + oDc.scrollLeft;
            case 2:
                return oObj.getBoundingClientRect().bottom + oDc.scrollTop;
            case 3:
                return oObj.getBoundingClientRect().left + oDc.scrollLeft;
            }
      } else {
            if (nDire == 1 || nDire == 3) {
                nPosition = oObj.offsetLeft;
            } else {
                nPosition = oObj.offsetTop;
            }
            if (arguments != 0) {
                if (nDire == 1) {
                  nPosition += oObj.offsetWidth;
                } else if (nDire == 2) {
                  nPosition += oObj.offsetHeight;
                }
            }
            if (oObj.offsetParent != null) {
                nPosition += mSift_SeekTp(oObj.offsetParent, nDire, 0);
            }
            return nPosition;
      }
    }
    function mSift(cVarName, nMax) {
      this.oo = cVarName;
      this.Max = nMax;
    }
    mSift.prototype = {
      Varsion : 'v2010.10.29 by AngusYoung | mrxcool.com',
      Target : Object,
      TgList : Object,
      Listeners : null,
      SelIndex : 0,
      Data : [],
      ReData : [],
      Create : function(oObj) {
            var _this = this;
            var oUL = document.createElement('ul');
            oUL.style.display = 'none';
            oObj.parentNode.insertBefore(oUL, oObj);
            _this.TgList = oUL;
            oObj.onkeydown = oObj.onclick = function(e) {
                _this.Listen(this, e);
            };
            oObj.onblur = function() {
                setTimeout(function() {
                  _this.Clear();
                }, 100);
            };
      },
      Complete : function() {
      },
      Select : function() {
            var _this = this;
            if (_this.ReData.length > 0) {
                _this.Target.value = _this.ReData.replace(
                        /\*/g, '*').replace(/\|/g, '|');
                _this.Clear();
            }
            setTimeout(function() {
                _this.Target.focus();
            }, 10);
            _this.Complete();
      },
      Listen : function(oObj) {
            var _this = this;
            _this.Target = oObj;
            var e = arguments;
            var ev = window.event || e;
            switch (ev.keyCode) {
            case 9://TAB
                return;
            case 13://ENTER
                _this.Target.blur();
                _this.Select();
                return;
            case 38://UP
                _this.SelIndex = _this.SelIndex > 0 ? _this.SelIndex - 1
                        : _this.ReData.length - 1;
                break;
            case 40://DOWN
                _this.SelIndex = _this.SelIndex < _this.ReData.length - 1 ? _this.SelIndex + 1
                        : 0;
                break;
            default:
                _this.SelIndex = 0;
            }
            if (_this.Listeners) {
                clearInterval(_this.Listeners);
            }
            _this.Listeners = setInterval(function() {
                _this.Get();
            }, 10);
      },
      Get : function() {
            var _this = this;
            if (_this.Target.value == '') {
                _this.Clear();
                return;
            }
            if (_this.Listeners) {
                clearInterval(_this.Listeners);
            }
            ;
            _this.ReData = [];
            var cResult = '';
            for ( var i = 0; i < _this.Data.length; i++) {
                if (_this.Data.toLowerCase().indexOf(
                        _this.Target.value.toLowerCase()) >= 0) {
                  _this.ReData.push(_this.Data);
                  if (_this.ReData.length == _this.Max) {
                        break;
                  }
                }
            }
            var cRegPattern = _this.Target.value.replace(/\*/g, '*');
            cRegPattern = cRegPattern.replace(/\|/g, '|');
            cRegPattern = cRegPattern.replace(/\+/g, '\\+');
            cRegPattern = cRegPattern.replace(/\./g, '\\.');
            cRegPattern = cRegPattern.replace(/\?/g, '\\?');
            cRegPattern = cRegPattern.replace(/\^/g, '\\^');
            cRegPattern = cRegPattern.replace(/\$/g, '\\$');
            cRegPattern = cRegPattern.replace(/\(/g, '\\(');
            cRegPattern = cRegPattern.replace(/\)/g, '\\)');
            cRegPattern = cRegPattern.replace(/\[/g, '\\[');
            cRegPattern = cRegPattern.replace(/\]/g, '\\]');
            cRegPattern = cRegPattern.replace(/\\/g, '\\\\');
            var cRegEx = new RegExp(cRegPattern, 'i');
            for ( var i = 0; i < _this.ReData.length; i++) {
                if (_this.Target.value.indexOf('*') >= 0) {
                  _this.ReData = _this.ReData.replace(/\*/g, '*');
                }
                if (_this.Target.value.indexOf('|') >= 0) {
                  _this.ReData = _this.ReData.replace(/\|/g, '|');
                }
                cResult += '<li style="padding:0 5px;line-height:20px;cursor:default;"onmousedown="'
                        + _this.oo
                        + '.Select();">'
                        + _this.ReData
                              .replace(
                                        cRegEx,
                                        function(s) {
                                          return '<span style="background:#ff9;font-weight:bold;font-style:normal;color:#e60;">'
                                                    + s + '</span>';
                                        });
                +'</li>';
            }
            if (cResult == '') {
                _this.Clear();
            } else {
                _this.TgList.innerHTML = cResult;
                _this.TgList.style.cssText = 'display:block;position:absolute;background:#fff;border:#090 solid 1px;margin:-1px 0 0;padding: 5px;list-style:none;font-size:12px;';
                _this.TgList.style.top = mSift_SeekTp(_this.Target, 2) + 'px';
                _this.TgList.style.left = mSift_SeekTp(_this.Target, 3) + 'px';
                _this.TgList.style.width = _this.Target.offsetWidth - 12 + 'px';
            }
            var oLi = _this.TgList.getElementsByTagName('li');
            if (oLi.length > 0) {
                oLi.style.cssText = 'background:#36c;padding:0 5px;line-height:20px;cursor:default;color:#fff;';
            }
      },
      ChangeOn : function(oObj) {
            var oLi = this.TgList.getElementsByTagName('li');
            for ( var i = 0; i < oLi.length; i++) {
                oLi.style.cssText = 'padding:0 5px;line-height:20px;cursor:default;';
            }
            oObj.style.cssText = 'background:#36c;padding:0 5px;line-height:20px;cursor:default;color:#fff;';
      },
      Clear : function() {
            var _this = this;
            if (_this.TgList) {
                _this.TgList.style.display = 'none';
                _this.ReData = [];
                _this.SelIndex = 0;
            }
      }
    }
</script>
</head>
<body>
    <form name="salefrm" method="post" action="result.jsp">
      <input type="text"name="name" id="abc" size="40" />
      <input type="submit" value="搜索" />
    </form>
    <script type="text/javascript">
   
    //建立实例,第一个参数是实例对象的名称,第二个是最多显示的数量
    var oo = new mSift('oo', 20);
    //获取数据
    function loadXMLDoc(str) {
      var xmlhttp;
      if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp = new XMLHttpRequest();
      } else {// code for IE6, IE5
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
      }
      xmlhttp.onreadystatechange = function() {
            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                oo.Data = xmlhttp.responseText.split("|");
            }
      };
      xmlhttp.open("GET", "AjaxServlet?name="+str, true);
      xmlhttp.send();
    }
   
      //指定文本框对象建立特效
      oo.Create(document.getElementById('abc'));
    </script>
</body>
</html>
AjaxServlet.java

public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    response.setContentType("text/xml; charset=utf-8");
    PrintWriter out = response.getWriter();
    String str = newsDao.findAllNewsType();
    out.println(str);
}
以上就是主要代码,数据库查询后返回的是以"|"分割连接的字符串组合(PS:图省劲嘛)。

https://www.uoften.com/program/jsp/20180413/47674.html
页: [1]
查看完整版本: JSP + ajax实现输入框自动补全功能 实例代码