这几天项目中要用到模糊搜索的功能,所以仿百度下拉菜单,结合所学知识完成相关任务,话不多说直接上当代码

1、HTML

<div>
<s:textfield name="videoName" id="videoNameId"
onkeyup="getTip(this);" value="请输入要搜索的视频名称"
onmousedown="changeInfo(this)" cssstyle="width:150px" />
</div>

2、JavaScript

<script type="text/javascript">

//点击输入框,“请输入要搜索的视频名称”消失
var changeInfo = function(input){
if(input.value == "请输入要搜索的视频名称"){
input.value = "";
}
};

//创建一个XMLHttpRequest对象

function createXMLHttpRequest() {
var xmlHttp;

try {
// Firefox,Opera 8.0+,Safari
xmlHttp = new XMLHttpRequest();
} catch (e) {

// Internet Explorer
try {
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {

try {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {
alert("您的浏览器不支持AJAX!");
return false;
}
}
}
return xmlHttp;
}

var getTip = function(video) {
var xmlHttp = createXMLHttpRequest();
if (xmlHttp == null) {
return;
}
var list = document.getElementById("listItem");
var videoName = video.value;
var isie = (document.all) ? true : false;//判断是IE内核还是Mozilla
//根据不同的内核进行不同的事件判断
if (isie) {
if (window.event.keyCode == 40) {
//下拉列表获得焦点
list.focus();
//第一个选项被选中
list.options[0].selected = "selected";
//文本框中值发生改变
document.getElementById("videoName").value = list.options[0].text;

//如果选项改变,那么相应值也要改变
list.onchange = function() {
var index = this.selectedindex;
list.options[index].selected = "selected";
document.getElementById("videoName").value = list.options[index].text;
};
//当失去焦点时,下拉菜单消失
list.onblur = function(){
list.style.display = "none";
};
return;
}
}
var url = "video_getTip.action?videoName=" + videoName;

//设置回调函数
xmlHttp.onreadystatechange = function() {
if (xmlHttp.readyState == 4) {
document.getElementById("showItem").innerHTML = xmlHttp.responseText;
}
};
//对URL进行字符集处理
url = encodeURI(url);
//准备发送
xmlHttp.open("get",url,true);
//发送请求
xmlHttp.send(null);
};
</script>

3 、ACTION

// 进行模糊查询( 范例 )
List<Video> videos = null;
// 特定条件查询
if (videoName != null) {
if (videoName.equals("请输入要搜索的视频名称")) {
videoName = "";
}
videoName = new String(videoName.getBytes("ISO-8859-1"),"UTF-8");
String newVideoName = "%" + videoName + "%";
videos = videoService.findByVideoName(newVideoName);
}
StringBuffer sb = new StringBuffer();
sb.append("<select id='listItem' name='listItem' style='width:150px;font-size:larger;position: absolute;' multiple='multiple'>");
// 拼接字符串,将数据返回
for (int i = 0; i < videos.size(); i++) {
sb.append("<option value='" + i + "'>" + videos.get(i).getName()
+ "</option>");
}
sb.append("</select>");
inputStream = new ByteArrayInputStream(sb.toString().getBytes("UTF-8"));
return "videoNameInfo";

4、Struts相关配置

//返回结果配置

<result name="videoNameInfo" type="stream">
<!-- 指定Stream生成的响应数据的类型 -->
<param name="contentType">text/html</param>

<!-- 指定由getResult()方法返回输出结果InputStream -->
<param name="inputName">result</param>

</result>

注意:在实现相关功能时,可能发生乱码,请注意编码格式,包括数据库、页面、请求等

相关效果图

仿百度下拉菜单 Ajax + struts2的更多相关文章

  1. HTML5单选框、复选框、下拉菜单、文本域的实现代码

    这篇文章主要介绍了HTML5单选框、复选框、下拉菜单、文本域的实现代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. 应用程序关闭时的iOS任务

    我正在构建一个应用程序,通过ajax将文件上传到服务器.问题是用户很可能有时不会有互联网连接,并且客户希望在用户重新连接时安排ajax调用.这可能是用户在离线时安排文件上传并关闭应用程序.应用程序关闭时可以进行ajax调用吗?

  3. Swift 字符串替换/过滤/切割/拼接

    替换为/结果过滤过滤掉单个字符/结果过滤掉开头和结尾的空白结果切割对字符串使用/作为分隔符来切割,不允许空字符串使用split函数结果是一个数组对字符串使用/作为分隔符来切割,允许空字符串结果拼接结果

  4. Swift开发教程--字符串的操作

    替换把?替换为/结果

  5. Swift下拉菜单动画实现

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  6. swift 网络搜索热词排行

    1.使用www.showapi.com上的接口,需要注册添加一个App,这样才能获取appid和secret密钥,调用前需要订购套餐(选免费的就可以了);2.外部库Podfile文件内容,SnapKit这里暂时不需要用到:3.桥接头文件参考:http://www.jb51.cc/article/p-pcleyxep-te.html4.AppTransportSecurityhasblockedac

  7. 使用视图控制器的切换创建下拉菜单栏

    下拉菜单则是另一种常用的菜单设计。当用户点击菜单按键的是时候主屏幕中下拉显示出菜单选项。如果你不知道下拉菜单是如何实现的话,不需要忧虑。在展示下拉菜单的实现之前,这篇文章已经假设你对自定义视图切换有一定的了解。下拉菜单功能的开始演示在这篇教程中我们会用Swift语言来实现下拉菜单,下面就是最终效果的一个快速展示:工程模版和以往一样,我不希望你从头开始,你可以先去下载起始工程。

  8. Swift 类似美团下拉菜单

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  9. 如何在Swift中打乱数组?

    如何随机化或混洗Swift中的数组中的元素?例如,如果我的数组包括52张扑克牌,我想洗牌,以便洗牌。这个答案详细说明了如何在Swift的各种版本中添加Fisher-Yatesshuffle。Swift3版本是最宽松的,但是它们至少可以用于数组。每个Swift版本的命名和行为与该版本的mutating和nonmutating排序方法相匹配。

  10. unit-testing – 如何在Swift中对NSFetchedResultsController进行单元测试

    我有一个Swift应用程序,它使用NSFetchedResultsController从持久存储中获取List对象:它的工作方式与预期的一样,我将List对象描述打印到控制台.我想为我的应用程序编写一些单元测试,所以我创建了扩展XCTestCase的类.代码编译没有问题,测试运行,但不幸的是我无法在该上下文中获取List对象.我在控制台中获得的所有内容都是List对象的数量和致命错误:线路上升:我

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部