l 1.1使用JavaScript获得浏览器内置的AJAX引擎(XMLHttpRequest对象)

l 1.2 通过AJAX引擎确定请求路径和请求参数

l 1.3 通知AJAX引擎发送请求

l AJAX引擎会在不刷新浏览器地址栏的情况下,发送请求

l 2.1 服务器获得请求参数

l 2.2 服务器处理请求参数(添加、查询等操作)

l 2.3 服务器响应数据给浏览器

l AJAX引擎获得服务器响应的数据,通过执行JavaScript的回调函数将数据传递给浏览器页面。

l 3.1 通过设置给AJAX引擎的回调函数获得服务器响应的数据

l 3.2 使用JavaScript在指定的位置,显示响应数据,从而局部修改页面的数据,达到局部刷新目的。

l $.post() 以post请求方式发送ajax

格式:jQuery.post(url, [data], [callback], [type])

参数1:url,请求路径

参数2:data,请求参数

参数3:callback,回调函数

参数4:type,返回内容格式,xml, html, script, json, text, _default。

服务器响应编码为:application/json;charset=UTF-8,回调函数data类型是json对象

服务器响应编码为:text/html;charset=UTF-8,回调函数data类型是字符串。

l 常用对象:

n JSONObject, java对象(JavaBean、Map)与JSON数据 转换工具类  对象和map集合

n JSONArray,java集合(List、Array) 与JSON数据 转换工具类

键盘按下和抬起 实现的ajax查询数据库显示下拉列表

条件查询的 拼音和文字都匹配的代码

* 条件查询商品

* @param condition

* @param params

* @return

*/

public List<Product> findAll(String word) throws SQLException{

StringBuilder builder = new StringBuilder();

List<Object> paramsList = new ArrayList<Object>();

if(word != null){

// 拼凑关键字的属性,hao拼凑成“%h%a%o%”

StringBuilder wordBuilder = new StringBuilder();

wordBuilder.append("%");

for(int i = 0 ; i < word.length() ; i ++ ){

wordBuilder.append(word.charAt(i)).append("%");   append 可以连着拼接

}

//1 汉字匹配

builder.append(" and pname like ?");

paramsList.add(wordBuilder.toString());

//2 拼音匹配

builder.append(" or pinyin like ?");

paramsList.add(wordBuilder.toString());

}

//转换成需要的条件

String condition = builder.toString();

Object[] params = paramsList.toArray();

QueryRunner queryRunner = new QueryRunner(C3P0Utils.getDataSource());

String sql = "select * from product where 1=1 " + condition;

return queryRunner.query(sql, new BeanListHandler<Product>(Product.class), params);

}

前台页面js代码

//自动填充

$(function(){

$("#search").keyup(function(){

var url = "/day15_autocomplete/productFindByWordServlet";

var word = $(this).val();  获取用户输入的数据作为参数

if(word == "") {

//如果没有输入关键字,隐藏提供区域

$("#completeShow").slideUp(200);

return false;

}

var params = {"word":word};

$.post(url,params,function(data){

$("#completeShow").html("<ul id='itemul' class='list-group'></ul>");

for(var i = 0 ; i < data.length ; i ++){

var product = data[i];

//处理关键字显示

var str = ""+product.pname + "("+ product.pinyin +")";

$("#itemul").append("<li class='list-group-item'><a href='#'>"+str+"</a></li>");

$("#completeShow").show();

}

});

}).focus(function(){

//获得焦点时,如果有搜索项显示

if($("#completeShow li").size() > 0){

$("#completeShow").show();

}

}).click(function(){

//如果点击的是文本框,阻止点击事件,及不触发document的click事件

return false;

});

/**

* 点击其他位置时,隐藏提示区域

*/

$(document).click(function(){

$("#completeShow").slideUp(200);

});

});

Ajax 执行流程 有用 一点的更多相关文章

  1. jQuery-1.9.1源码分析系列(十六)ajax——ajax处理流程以及核心函数

    先来看一看jQuery的ajax核心处理流程($.ajax) a. ajax( [url,] options )执行流程 第一步,为传递的参数做适配.url可以包含在options中 //传递的参数只 ...

  2. SpringMVC--从理解SpringMVC执行流程到SSM框架整合

    前言 SpringMVC框架是SSM框架中继Spring另一个重要的框架,那么什么是SpringMVC,如何用SpringMVC来整合SSM框架呢?下面让我们详细的了解一下. 注:在学习SpringM ...

  3. [Java编程思想-学习笔记]第4章 控制执行流程

    4.1  return 关键字return有两方面的用途:一方面指定一个方法结束时返回一个值:一方面强行在return位置结束整个方法,如下所示: char test(int score) { if ...

  4. asp.net MVC4的执行流程

    MVC在底层和传统的asp.net是一致的,在底层之上,相关流程如下: 1)Global.asax里,MvcApplication对象的Application_Start()事件中,调用 RouteC ...

  5. 从源码角度看finish()方法的执行流程

    1. finish()方法概览 首先我们来看一下finish方法的无参版本的定义: /** * Call this when your activity is done and should be c ...

  6. ASP.NET MVC4 执行流程

    MVC在底层和传统的asp.net是一致的,在底层之上,相关流程如下: 1)Global.asax里,MvcApplication对象的Application_Start()事件中,调用 RouteC ...

  7. ThinkPHP中的跨控制器调用与框架执行流程

    一.跨控制器调用 UserController.class.php <?php namespace Home/Controller use Think/Controller class User ...

  8. angularjs源码分析之:angularjs执行流程

    angularjs用了快一个月了,最难的不是代码本身,而是学会怎么用angular的思路思考问题.其中涉及到很多概念,比如:directive,controller,service,compile,l ...

  9. Monkey源代码分析之执行流程

    在<MonkeyRunner源代码分析之与Android设备通讯方式>中.我们谈及到MonkeyRunner控制目标android设备有多种方法.当中之中的一个就是在目标机器启动一个mon ...

随机推荐

  1. QCon2016 上海会议汇总(2) - 团队管理

    QCon 2016上海日程:http://2016.qconshanghai.com/schedule <当你的团队还支撑不起梦想时> - 链尚网技术合伙人 杨荣伟 Figo讲述了如何训练 ...

  2. c的详细学习(4)选择结构与循环结构的编程练习

        本节介绍c语言的编程实例.     (1)求方程ax^2+bx+0的解: 方程有解有以下几种可能: 1.b^2-4ac=0,方程有两个相等实根. 2.b^2-4ac>0,方程有两个不等实 ...

  3. c的详细学习(6)函数

        根据模块化程序设计的原则,一个较大的程序一般要分为若干个小模块,每个模块实现一个比较简单的功能.在c语言中,函数是一个基本的程序模块.     (1)函数的基本概念: 1)基本介绍: 任何一个 ...

  4. MD5文件

    我从某网站下载了一个iso系统镜像,我担心下载下来之后,被我电脑上的病毒感染了.我要确定这个文件还是“原汁原味”,就可以用软件再次生成该文件的md5码,然后和网站上的md5码对比一下就可以了.我用的是 ...

  5. leetcode 1049 Last Stone Weight II(最后一块石头的重量 II)

    有一堆石头,每块石头的重量都是正整数. 每一回合,从中选出任意两块石头,然后将它们一起粉碎.假设石头的重量分别为 x 和 y,且 x <= y.那么粉碎的可能结果如下: 如果 x == y,那么 ...

  6. 【leetcode刷题笔记】Reverse Nodes in k-Group

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. If ...

  7. matlab函数之imresize()

    B = imresize(A,scale) B = imresize(A,scale) 返回图像 B,它是将 A 的长宽大小缩放 scale 倍之后的图像.输入图像 A 可以是灰度.RGB 或二值图像 ...

  8. 基于js的网页换肤(不需要刷新整个页面,只需替换css文件)

    1. [代码][JS]代码    <HTML><HEAD><link ID="skin" rel="stylesheet" typ ...

  9. Fireworks(whole page)

    <!DOCTYPE HTML> <html> <head> <title>Canvas 实现放烟花特效</title> <meta c ...

  10. 用express实现CORS跨域(上-简单请求)

    今天遇到了一个跨域请求登录验证的问题.所以有了尝试跨域的机会. 具体情景是,有一个登录界面写在名叫cas的站点上,但是相关的登录验证的后台接口是写在名叫earth的站点. 首先的反应是使用jsonp, ...