黑马程序员技术交流社区

标题: 【厦门JavaEE就业1期-每日总结】jQuery&Ajax [打印本页]

作者: 厦门校区    时间: 2018-6-12 22:02
标题: 【厦门JavaEE就业1期-每日总结】jQuery&Ajax
同学们,今天我们主要讲的就是Ajax,这是很重要的一个技术点,主要作用就是来做异步提交。

今日需要掌握的有:

请同学们按照如上要求,总结今日所学。






作者: chenyelong    时间: 2018-6-12 23:25
陈叶隆
JQuery的AJAX部分方法:
* Jq的对象.load(路径,参数,回调函数);
* $.get(路径,参数,回调函数,数据类型);
* $.post(路径,参数,回调函数,数据类型);

案例一:使用JQ完成对用户名异步校验的功能:
1:设计一个注册页面
2:在用户名的文本框中使用onblur事件触发一个函数.
3:使用JQ的AJAX完成异步操作,将文本框的值传入到Servlet中.
4:Servlet中根据传入的用户名去数据库进行查询.
5:查询到了说明用户名已经被占用,没有查询到说明用户名可以使用.
$(function(){
        $("#username").blur(function(){
                // 获得文本框的值:
                var username = $(this).val();
                $.get("/day15/ServletDemo3",{"username":username},function(data){
                        if(data == 0){
                                $("#s1").html("<font color='green'>用户名可以使用</font>");
                                $("#regBut").attr("disabled",false);
                        }else if(data ==1){
                                $("#s1").html("<font color='red'>用户名已经存在</font>");
                                $("#regBut").attr("disabled",true);

案例二:使用JQ完成仿百度提示页面:
$(function(){
                $("#word").keyup(function(){
                // 获得文本框的值:
                var word = $(this).val();
                // 异步发送请求:
                if(word != ""){
                        $.post("/day15/Servlet1",{"word":word},function(data){
                                $("#d1").show().html(data);
                        });
                }else{
                        $("#d1").hide();

作者: 滴滴eclipse启动    时间: 2018-6-12 23:27
江某人:

今天学习了AJAX和Jquery异步:
AJAX的概述: AJAX:异步的 JavaScript And XML.
                使用的是老的技术,用的是新的思想.
            AJAX的功能:完成页面的局部刷新,不中断用户的体验
            仿百度提示案列 把list集合存入sequence中 在一个新的页面中循环输出
作者: 名字被人注册了    时间: 2018-6-12 23:48
刘文峰
Ajax是一种异步刷新网页的技术,可以不用刷新整个页面只让页面局部刷新,不影响页面浏览.现在较为常用的是jquery和ajax结合的技术,代码量少.
常用方法
Jq的对象.load(路径,参数,回调函数);
$.get/post(路径,参数,回调函数,数据类型);

校验用户名:
给文本框添加一个失去焦点事件;获得文本框的值(用户名);调用ajax的方法就可以将数据传递给servlet;到数据库查询用户名是否重复,然后将结果响应给jsp:
使用load方法校验时,响应的结果会被直接写进jsp里(response.getWriter().print(结果));
$.get/post方法校验,可以将结果响应给回调函数括号里的参数,然后可以对参数进行判断,最后在将结果写进jsp里,比load方法多了一步,但是相对的灵活很多.
黑马一下:
给文本框添加一个键盘抬起(keyup)事件;获得文本框的值(查询的);调用ajax的方法就可以将数据传递给servlet:
使用$.get或$.post方法,到数据库使用模糊查询(like)和limit查询多条记录,将记录封装成一个集合,使用请求转发跳到另一个jsp页面(将head及head元素里的所有东西删掉),在页面里可以将集合遍历,页面里的内容会被保存到回调函数的参数里,然后就可以将结果写进一个div里,div设置成隐藏,文本框里有内容可以显示,没有就不显示
作者: Eclipse启动    时间: 2018-6-13 00:44
郑阳阳
AJAX是一个可以向服务器异步发送请求的技术,使用老技术,新思想.
同步与异步:
同步就是点击链接或者提交数据页面才会跳转,整个页面都会刷新.
刷新过程中页面空白,用户体验全无.
异步是点击链接或者提交数据只有局部的页面会进行刷新,
用户可以浏览其余部位的页面,不会中断用户体验.
使用JQ可以更简单的使用AJAX:
jq对象.load(路径,参数,回调函数)
$.get(路径,参数,回调函数,数据类型)
$.post(路径,参数,回调函数,数据类型)
$.ajax();一般不使用,和直接使用AJAX差不多
serialize(); JQ的AJAX传递参数是需要使用
作者: 光宇    时间: 2018-6-13 00:46
侯玉林
1.什么是AJAX(JavaScript And XML):
        js中的一种异步交互技术,通过该技术可以在页面中进行局部刷新.
        核心:当使用了ajax后,浏览器接收了从服务器发送过来的数据时,不再
        直接刷新页面,而是直接传给js中的ajax对象,实现局部刷新.
2.同步和异步的区别:
        参考图一:
3.AJAX的功能:
        完成页面的局部刷新,不中断用户的体验.
4.ajax的历史:
        * 早期的时候JS技术根本不受重视.后台开发人员经常将JS当成一种玩具式语言.JS中有一个对象XMLHttpRequest对象可以向服务器异步发送请求.传统的B/S结构的软件,所有实现功能都需要在服务器端编写代码(胖服务器).现在有了AJAX以后,可以将部分代码写到客户端浏览器(RIA:Rich Internet Application).FLEX:AS脚本编程.
        * XML:使用XML做为数据传递的格式: JSON:
5.属性:
        * readyState                        :XMLHttpRequest的状态
        * onreadystatechange        :当XMLHttpRequest状态改变的时候触发一个函数.
        * status                                :获得响应的状态码. 200 , 404 ...
        * responseText                        :获得响应的文本数据.
        * responseXML                        :获得响应的XML的数据.
5.方法:
        * open(请求方式,请求路径,是否异步)                :异步去向服务器发送请求.
        * send(请求参数)                                                :发送请求.
        * setRequestHeader(头信息,头的值)                :处理POST请求方式的中文问题.
                创建XMLHttpRequest对象:
        * IE                :将XMLHttpRequest对象封装在一个ActiveXObject组件.
        * Firefox        :直接就可以创建XMLHttpRequest对象.

作者: hpb199567    时间: 2018-6-13 12:15
AJAX和JQ
何平波
概述:异步的JavaScript and xml
功能:完成页面的局部刷新,不中断用户的体验
XML:使用XML作为数据的格式
XMLHttpRequest对象
方法:
open(请求方式,请求路径,是否异步):异步去向服务器发送请求
send(请求参数):发送请求
setRequestHeader(头信息,头的值):处理POST请求方式的中文问题

JQuery的AJAX部分方法:
Jq的对象.load(路径,参数,回调函数);
$.get(路径,参数,回调函数,数据类型);
$.post(路径,参数,回调函数,数据类型);
$.ajax();
serialize(); -- JQ的AJAX传递参数的时候需要使用的方法.

生词:disabled  让按钮隐藏或者是显示
     attr 修改的缩写
AJAX到底是什么?
其实的话,ajax


案例一总结利用JQ的Ajax方法在注册用户的时候局部刷新提示用户名是否存在
0.引入Js文件
1.先有一个注册页面
2.有表单(表单有id,这里可以jq获取id,然后获取这个id里的值)  提交按钮(有id.这里的id添加一个功能是让用户名存在的话就让注册按钮失效)
3.这里直接可以在注册页面写JQ函数方法,不过为了代码页面的整洁,建议写一个js文件,然后在页面引入
4.获取文本框id,触发一个失去焦点事件,取到表单输入的数据
5.JQ的ajax方法 get(路径,参数,回调函数,数据类型);  $.get("/AjaxAndJQ/TipsServlet",{"username" : username},function(date)
6.判断输入的用户名如果跟数据库一样,提示用户名已存在,反之.
7.可以添加提交功能,如果用户名输入为空或者存在,让注册按钮失效.
$("#subBut").attr("disabled",false) 让注册按钮不会失效
$("#subBut").attr("disabled",true)        让注册按钮失效
var username = $(this).val();  //!!!!!!!  val();  是一个方法  记得加括号

案例二总结仿百度搜索
需求:点一个搜索框,跳出查询的信息的div,可以规定查询多少条,没有输入信息的话,div自动隐藏
这里涉及了jsDom的事件keyup(键盘抬起事件),而且查询的信息要封装进一个集合,根据条件模糊查询信息(包含一个关键词的like'%输入的字%',在like子句中可以使用_或者%作为占位符,_只能代表一个字符,%可以代表任意个字符.),
将查询到的list集合(集合里已经有要查询的信息了),再在一个jsp的页面将这些信息遍历.
$.get("/AjaxAndJQ/SerchServlet",{"username":username},function(data){
"/AjaxAndJQ/SerchServlet":路径   
{"username":username}:前一个是表单的name属性,后一个是表单的数据,这里等同于String username = request.getParameter("username")
function(data);date:一个JSP文件所存的所有的字符串数据,既可以拿到所存的list信息.
$("#d1").show().html(data):id为d1的div写入html所有的date数据,show()显示,前提是这个div要先隐藏.这里有一个判断,如果获取到的信息
不为空的话,那么这个方法就会生效,反之将继续隐藏.
作者: 渣..    时间: 2018-6-13 13:28
柯威龙
今天主要学习了jquery的AJAX部分功能和新知识点AJAX.在学习今天知识点之前我首先学习了什么是
同步异步.同步就是页面的跳转,在jsp页面中我们直接将数据提交到Servlet中.异步是在Servlet中
直接进行数据接收或者处理.数据直接在js和jsp页面中进行操作.AJAX的主要功能也是完成页面的局部
刷新.不中断用户的体验.还学习了HttpRequest对象的部分属性和功能.在使用AJAX的时候有三种编写
的方法.get和post两种,还有一种是使用jq对象.load方法的只需要了解.步骤大概分为四步.
1.创建一个异步对象.
2.设置对象状态改变触发一个函数.
3.设置向后台提交的数据.
4.发送请求

作者: q55w66    时间: 2018-6-14 11:02
王清松
AJAX(Asynchronous JavaScript And XML)
        概述
                完成页面的局部刷新,不中断用户的体验
                使用XML作为数据传递的格式
        入门(了解)
                XMLHttpRequest对象
                        属性
                                onreadystatechange:当XMLHttpRequest状态改变的时候触发一个函数
                                readyState:XMLHttpRequest状态
                                        0未初始化
                                        1初始化
                                        2发送数据
                                        3数据传送中
                                        4完成
                                status:获得响应的状态码(200,404....)
                                responseText:获得响应的文本数据
                                responseXml:获得响应的XML数据
                        方法
                                open(请求方式,请求路径,是否异步):异步去向服务器发送请求
                                send(请求参数):发送请求
                                        get方式请求参数写在请求路径中
                                setRequestHeader(头信息,头的值)
                                        处理Post请求方式的中文问题
                        创建XMLHttpRequest对象
                                IE:将XMLHttpRequest对象封装在一个ActiveXObject组件
                                        低版本:var Xhr=new ActiveXObject("Msxml2.XMLHTTP");
                                        高版本:var Xhr=new ActiveXObject("Microsoft.XMLHTTP");
                                Firefox:直接可以创建XMLHttpRequest对象
                                        var Xhr=new XMLHttpRequest();
                实现传统方式的AJAX
                        GET方式提交请求
                                第一步:创建一个异步对象
                                        var xhr=getXhr()
                                                function getXhr(){
   var xmlHttp;
   try{ // Firefox, Opera 8.0+, Safari
        xmlHttp=new XMLHttpRequest();
    }
    catch (e){
           try{// Internet Explorer
                 xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
              }
            catch (e){
              try{
                 xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
              }
              catch (e){}
              }
    }

        return xmlHttp;
}
                                第二步:设置对象状态改变来触发一个函数
                                        xhr.onreadystatechange = function(){
        if(xhr.readyState==4){//请求发送成功
                if(xhr.status==200){//响应也成功
                        var date=xhr.responseText;//获得响应的文本数据
                        document.getElementById("id").innerHTML=data;//数据写入
                }
        }
}
                                第三步:设置向后台提交的路径
                                        xhr.open("GET","/MyWeb/Servlet",true)
                                        如果要传参数,需要在路径后面用?
                                第四步:发送请求
                                        xhr.send(null)
                        POST方式提交请求
                                比起GET需要多设置一个头信息(open下方)
                                        xhr.setRequestHeader
("Content-Type","application/x-www-form-urlencoded")
                                        第二个参数的值等于<form>表单的属性enctype的值
                                传参通过第四步发送请求时设置
                                        xhr.send("name=Kingdon&password=123")
        JQuery操作AJAX
                (JQ对象).load(路径,参数,回调函数)
                        默认GET方式,传递参数后自动转换为POST方式
                        获得的数据直接写在JQ对象标签的中间
                $.get(路径,参数,回调函数,数据类型)
                        数据类型不传默认返回字符串类型
                        也可以写XML,json
                $.post(路径,参数,回调函数,数据类型)
                        var name=$("#id").val();
$.post("/MyWeb/Servlet",{"name":name,"age":20},function(data){
        $("#div").html(data);
});
                        data可以自己命名,作为返回值
                        回调函数,指的是路径访问完毕后,拿到返回值后,执行的函数??
                $.ajax
                        传统的
                serialize()
                        JQ的AJAX传参的时候需要使用的方法
作者: 13163997058    时间: 2018-6-14 12:29
王刘锁
2018-6-12--JQuery&ajax..
通过今天的学习让我找到了自己的短板.发现自己对JQuery和js&html方面的知识基本为零,今天写案例基本败在jquery语法和属性上,回过头去翻笔记也只能想起个大概,很多还是不理解,找到了短板就要去补上,说一下今天学的ajax,javaScript and xml;一种可以在整个页面不刷新的情况下,只刷新一下部分页面的异步发送请求的技术,不会让我们再浏览网站时网速慢造成的网页卡在空白页现象,局部页面的刷新可以改善用户体验,传统的ajax使用方式做个了结就行,我们主要通过两个案例来学习ajax和jquery的结合使用,第一个案例是实现输入用户名,显示用户名是否已经存在.写一个注册界面,定义一个js文件然后引入到jsp中,在js文件中写代码,首先是jquery的入口函数$(function(){}),然后在入口函数大括号内用id选择器获取用户名文本框并添加失去焦点事件$("#username").blur(function(){}),在事件大括号内先获取输入的用户名,
var username =$(this).val();这里用的jq方式(总是忘记写括号还找不出是这个原因,这方面的知识实在太弱了),然后就是异步请求,$.get("请求路径/web_10/LoginServlet",参数{"username":username},响应结果function(data){});异步的重点就是把响应回来的数据写入到data中,然后用jquery来对data操作,把它显示在页面某一部分,这时我们再后台servlet中做的操作是用传过去的用户名去数据库查找,dao层返回查到的user对象,在servlet中判断user是否为空,为空说明用户名不存在可以注册,不为空说明用户名被占用,再根据这两种情况打印response.getWrit().print(0/1);0代表为空,1代表不为空,这里的打印其实就是打印到data中去了,然后我们可以在上面js文件中的响应结果大括号内写判断if(data==0){}else if(data==1){};分别在大括号内获取到jsp页面中用户名输入文本框后面添加的span标签,并写入文字提示$("#s1").html("想显示的内容为0显示可以使用为1显示不可以使用"),还可以设置不可以使用是注册按钮不可点击获取到按钮$("#bute").attr("disabled",false)-(是否禁用,否)这样这个案例的功能基本实现了,当然记得把js引入jsp中,
然后是第二个案例,仿百度搜索提示功能,思想上优点绕,不太好理解,首先写一个搜索页面,一个文本框,一个按钮,按钮没什么用,定义一个js文件,写代码还是jq入口$(function(){}),然后{}内写输入框的键盘抬起事件$("#text").keyup(function(){});事件括号内获取输入的值,var word =$(this).val();然后异步请求$.post("/web_10/SearchServlet",{"word":word},function(data){});后台通过输入的word去数据库模糊查询,返回一个list结果集合存入request域中转发到一个info.jsp的中间jsp文件,这里要注意的是再定义一个info.jsp.这个jsp中的其它自动生成的代码全部删掉,然后写遍历集合jstl的<c:forEach items="${list}">获取每一个word显示<td>${w.word}</td>,这里转发到info.jsp其实也是把jsp中的代码以字符串的形式写到data中,因为jsp会被翻译成servlet在编译成class文件,最后在Java文件中是print("代码")的形式,这里我们回到响应结果大括号内,开始操作data到搜索框下方隐藏的div中,获取到div$("#d1").show().html(data);这样div就显示出来并写入了info.jsp中的代码,经过浏览器识别执行,显示出查询到的数据,可以加上一个判断如果输入框的值为空就把div隐藏$("#d1").hide();到这里这个功能也基本完成,当然还可以加一些其他的特效.还是要抽空来复习jquery的知识!
作者: 小故事    时间: 2018-6-14 20:12
谢洪彬:
JQery&AJAX’
AJAX:异步
今天的学习先回顾了JQery,后面又学习了新的知识AJAX
这里先要说一下同步和异步的区别,同步是等页面全部加载完毕后,浏览器才显示内容,这段时间浏览器是空白的,会造成客户体验差,而异步则是加载完一部分显示一部分,这样在加载的过程中我们也可以浏览到内容
JQery的回顾及新知识的扩张:
隐藏DIV         display : show(显示)  none(隐藏)  jsp
js中可以获取DIV对象直接调用show()来显示,hide()来隐藏
$("#ID对象").html(“值”)--往这个对象标签中写数据
$("#ID对象").prop(‘属性’,) --给某个属性设置值
$("#ID对象").arrt(‘属性’,) --给某个属性设置值
$(this).val();--获取当前对象的value
使用JQery获取事件时,事件名不是以on开头
AJAX需要掌握的知识:
我们需要掌握AJAX中的get(),set()方法,也就是对应的getset方法
直接使用JQuery($)对象直接调用方法
两个方法中都有四个属性
1. 跳转的路径                url=””;
2. 传递的参数                 {“参数名”,参数值}
3. 回调函数      function(date){}
4. 参数的类型
执行顺序: 携带参数--跳转servlet路径--servlet执行完毕后执行回调函数,--带回来的参数会存放到data参数中;
我们还学习了AJAXload(),也就是加载方法,不过这个方法需要获取标签的对象来进行调用,不作为重点了解.

作者: 厦门黑马王子    时间: 2018-6-14 21:37
郑雪平

今天学习了如何使用AJAX来实现校验用户名是否存在和使用JQ来完成用户名是否存在的校验以及使用JQ来完成模仿百度提示页面的功能。什么是Ajaxs呢?它是异步的 JavaScript And XML,它使用的虽然是老技术,但是却是使用新的编译思想的,ajax的功能是能完成页面的局部刷新从而达到不中断用户体验过程的效果。ajaxd的编写步骤:1.创建一个异步对象;2.设置对象的状态被改变时触发一个函数事件;3.设置向后台提交的路径;4.发生请求。具体代码实现的步骤:1.创建数据库和表文件;2.创建一个注册页面;3.在文本框里使用Onblur事件来触发函数;4.将文本框中的值传入Servlet中;5.根据传入的用户名去数据库查询;6.根据查询结果显示用户名是否可用。
许多网站都会有类似搜索的功能,当在文本框中输入一个字母或者文字的时候,下面就会给出相应提示的信息,这个可以使用JQuery的AJAX的部分来完成.步骤:1.创建一个商品的搜索页面,2.使用键盘弹起keyup事件来触发一个函数,3.将获得的文本框里的值,提交到Servlet中;4.最后在Servlet中根据所提交的名称去查询相关的信息。
作者: 厦门陈强    时间: 2018-6-14 22:03
就是陈强
Jquery&AJAX的一天;
AJAX的功能就是完成局部的页面刷新,不中断用户的体验;
XMLHttpRequest是AJAX的核心:
-属性:1\onreadystatechange---(监听功能)状态改变就触发函数
                        --状态—五种(0,1,2,3,4)
        2\status---获得响应的状态码,就是之前代码出现bug的时候那些200,404,500....
        3\responseText---获得响应的文本数据
        4\responseXML---获得响应的XML
-方法:
        1\open---异步向服务器发送请求
        2\send---发送请求
        3\setrequestHeader---处理post请求中的中文乱码
然后是采用了Jquery的AJAX去实现异步校验;
-有5种的方法,但是我们采用的是get或者post方法:
        -$ . get ( 路径 , 参数 , 回调函数 , 数据类型 )
        -$ . post ( 路径 , 参数 , 回调函数 , 数据类型 )
代码实现过程中的逻辑,个人总结为:
1\访问JSP页面,
2\然后会执行到引入进来的JS中的页面一进来就加载的函数,
3\然后会携带获取到的text中的值调转到servlet
4\在servlet中处理数据并进行判断,将要打印的数据给到data
5\然后判断这个data并做出要执行的动作

作者: Yanmo_    时间: 2018-6-14 22:07
颜琳琳
今天学习了ajax异步的JavaScript and xml , 该技术是老技术但是使用的是新思想,主要在与JQuery相结合使用 , Ajax在的传统使用方法是用XMLHttpRequest来使用,XMLHttpRequest的属性有:1.readyState  :XMLHttpRequest的状态  2.onreadyStateChange  :XMLHttpRequest改变状态时触发的函数   3.status : 响应的状态码
4.responseText  :获取响应的文本数据  5.responseXML  :获取响应的XML数据
方法有:1. open(请求方式,请求路径,是否异步) :异步向服务器发送请求  2.send(请求参数) :发送请求   3.setRequestHande(头信息,头的值)  :处理post请求中的中文信息
Ajax传统的使用步骤如下:
1创建一个异步对象 2.设置一个对象来触发函数  3.设置后台提交的路径  4.发送请求
其中get和post的请求方式中的不同是:
get设置请求路径是xhr.open("GET","/day15/ServletDemo1?name= aaa&pass=123",true);
发送请求xhr.send(null);
而post是要打开路径:xhr.open("POST","/day15/ServletDemo1",true);
发送请求头:xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
发送请求:xhr.send("name=张三&pass=123");
Ajax主要使用的方法是和JQuery相结合使用:其中主要用到JQuery的方法有:
1.jq的对象.load(“请求路径”,”请求参数”,回调函数);
2.$.get(“请求路径”,”请求参数”,”回调函数”);
3.$.post(“请求路径”,”请求参数”,”回调函数”);
4.Serialize :JQ对Ajax传递参数用到的方法

作者: 铁木啊童臂    时间: 2018-6-14 22:56
汪志阳:
今天主要是Ajax的学习,Ajax是结合JQ语句使用的,
$(function() {
        $("#nameID").blur(function() {
                // 获取文本框的值
                var val = $(this).val();
                $.post("/day0608/LoginServlet",{"username":val},function(data){
                        if(data==2){
                                $("#spanID").html("<font color='red'>用户名已存在</font>")
                        }else if(data==1){
                                $("#spanID").html("<font color='green'>用户名可以注册</font>")
                        }
                })
        })
})
这是检验用户名是否被注册的运用.首先是JQ入口函数固定写法,然后获取在用户名的文本框中使用onblur事件触发一个函数的ID.
获取文本框的值,使用JQ的AJAX完成异步操作,将文本框的值传入到Servlet中,进行数据连接数据库进行查询处理,最后再返回给Ajax的回调函数function(data)
在js界面接收data,做最后的判断执行操作.
AJAX的常用语法:
$.get(路径,参数,回调函数,数据类型)
$.post(路径,参数,回调函数,数据类型)


作者: 凉面要趁热吃    时间: 2018-6-14 23:32
黄进安:

1.      JQuery的AJAX部分方法:
* Jq的对象.load(路径,参数,回调函数);
* $.get(路径,参数,回调函数,数据类型);
* $.post(路径,参数,回调函数,数据类型);
--->路径: 要跳转的地址参数: {"key":value} 回调函数: function(data){方法体} data:响应成功的数据
--->选用get或者是post方法取决于在服务器对应的servlet中,为了防止出现乱码使用的是get请求处理乱码还是post请求处理乱码,不对应的话出现中文会出现乱码现象导致功能无法实现
2.       使用JQ完成对用户名异步校验的功能:
l  在页面中导入jQuery包和相关的js文件
l  在用户名框使用失去焦点触发事件
l  在js文件中使用jQuery完成失去焦点事件触发后要进行的操作(使用get或者post方法,将用户输入的用户名提交到后台相关的servlet,然后完成对此用户名是否已经存在数据库的查询,根据查询的结果响应不同的数据给到js的回调函数(data),然后根据data的值进行相关操作即可)
3.       使用JQ完成仿百度提示页面
l  在页面中导入jQuery包和相关的js文件
l  在输入框使用键盘弹起事件
l  在js文件中使用jQuery完成键盘弹起事件触发后要进行的操作(使用get或者post方法,将输入框输入的值提交到后台相关的servlet,在Dao中使用模糊查询和指定查询结果数目(limit)的方式对数据库进行操作,根据查询结果的返回一个集合,把集合存储在request域中转发到jsp中采用jstl方式遍历,遍历的结果返回给到js的回调函数(data), 然后将data数据输出到提示页面的div中即可)



作者: LittleSky    时间: 2018-6-14 23:41
常小天
今天的学习了一样新的东西——AJAX。这是一种将老技术与新思想结合的产物。AJAX的基础是我们之前学习的js。AJAX最独特的功能就是实现异步访问服务器。所谓异步就是在不刷新当前页面的情况下向服务器发送请求,服务器响应后将响应的内容刷新到当前页面的一部分中。AJAX能够实现这一功能的基础是它有一个异步对象XMLHttpRequest。这个对象能够异步的访问服务器,它又一个属性readyState可以标识它的状态。0表示未初始化,1表示初始化,2表示发送数据,3表示数据传输中,4表示响应完成。而它的另一个属性onreadystatechange可以在它的属性发生变化时触发一个函数。要事项异步访问时,我们先创建一个异步对象,创建的方法直接引用。然后设置状态改变的监听,利用的就是onreadystatechange属性,触发方法,在方法中获得异步对象的状态和响应的状态码。当响应完成,也就是异步对象状态为4,并且响应状态码为200时,就可以接收响应回的数据。responseText获得响应的文本数据。 responseXML获得响应的XML的数据。最后利用js的选择器和写入方法将获得的数据写入到指定的区域内。这里post传递方法与get类似,只多了一步操作,就是在设置一个头信息:xhr.setRequestHeader("Content-Type", "application /x-www -form-urlencoded")。这就是AJAX实现异步的原理。而我们还进一步学习了AJAX与jQuery结合使用的方法,$.get(路径,参数,回调函数,数据类型)和 $.post(路径,参数,回调函数,数据类型)两个方法使我们的代码大大简化。
作者: doudou0606    时间: 2018-6-14 23:49
施炎生
今日总结:
一、使用JQ完成对用户名异步校验的功能:
引入两个JS文件
(<script type="text/javascript" src="${ pageContext.request.contextPath }/04_jq_regist/regist.js"></script>)
注册页面的regist.jsp找到引入的regist.js,执行该js文件的入口函数$(function(){},在该入口函数内继续执行用户名框的失去焦点方法,取得username的值,然后执行JQuery的AJAX部分方法:$.get(路径,参数,回调函数,数据类型);* $.post(路径,参数,回调函数,数据类型);),在Servlet取得返回值进行判断,输出用户名是否被占用语句,并通过$().attr(“disabled”,true或者false)使注册按钮失效或者有效。
二、仿百度提示页面
同上引入两个js文件, jsp找到js,执行该js文件的入口函数$(function(){},在该入口函数内继续键盘弹起方法,取得页面输入框里word的值,然后执行JQuery的AJAX部分方法:$.get(路径,参数,回调函数,数据类型);* $.post(路径,参数,回调函数,数据类型);),在Servlet取得符合查询条件的word值存到list集合,再把集合存到request域中,再转发到jsp(此处的jsp要把html代码删掉,不然这些代码会原样显示到我们要显示的jsp页面)中进行遍历把word值取出,之后回到js中把word值显示到页面jsp中。
三、异步请求和同步请求的区别:
异步请求---打印给data;
同步请求---打印给页面
异步请求---转发到jsp---打印给data;
同步请求---转发到jsp---打印给页面

作者: 张述明    时间: 2018-6-14 23:52
张述明
主要学习两个案例  
JQ异步实现注册用户名校验
第一步:注册页面的用户名栏添加name,id属性,<span id=?>用于信息提示,
       submit处添加id属性  引入js包 自己配置一个js文件   
       导包顺序先js后自己的js

js配置页面
$(function(){
//获得id触发blur事件
$("#id").blur(function(){
//获得文本框中的值   var username=$(this).val();
通过Ajax的$.get("路径 servlet",参数 例{"username":username},"回调方法"function(data){
if(data==1){
//通过id.html向span里打印用户名可用
//还可以通过id来实现用户名已存在,注册按钮失效,反之
可以通过id.attr("disabled",false);
}else if(data==2){
//通过id.html向span里打印用户名重复
通过id.attr("disabled",true);
}

} )

})

})

servlet界面
//接收用户名,request.getParameter("username");
//调用业务层  返回 一个User user
判断  if(user==null)
{
//说明数据库不存在,注册成功
向页面打印一个1   
}else{
//注册失败,打印一个2
}

service
//调用dao层的方法

dao
//查询username返回





案例二模仿百度提示词
首先你需要一个界面  导入一个js和自己配置的js
一个文本框设置id,name属性   一个按钮 设置value属性
div 设置id 隐藏属性  宽 高 边框 位置等


js页面
$(function(){

//通过id触发keyup函数
$("#id").keyup(function(){
//获得文本框的值
Var value=$(this).val();
$.get("路径servlet"""name":文本框的值"回调函数)
})
判断文本框的内容是否为空 不为空显示 调用show().html()  为空 hide() 继续掩藏div
})

servlet
获得参数的值,因为要在界面输出中文所以采用new String转译
调用业务层--dao 层- 返回一个list<>list集合
request.setAttribute("list",list);
转发 到一个"新的jsp"


jsp引入jstl,standard 包
设置一行一列表格
<C:forch var="p" item="${list}">   p.name


dao

sql采用模糊查询并限制个数
select*from表名where pname like? limit?

作者: 林荣彬    时间: 2018-6-15 00:08
林荣彬
   Jquery&AJAX的一天;
AJAX的功能:完成网页的局部刷新.不中断用户的体验
XML HttpRequest:
属性:
readyState:XMLHttpRequest的状态
onreadystatechange:当XMLHttpRequest状态改变的时候触发一个函数.
status        :获得响应的状态码. 200 , 404 ...
responseText:获得响应的文本数据.
responseXML:获得响应的XML的数据.

JQuery的AJAX:部分方法:
JQ的对象.load(路径,参数,回调函数)
$.get(路径,参数,回调函数,数据类型)
$post(路径,参数,回调函数)
$ajax();
serialize();----JQ的ajax传递参数的时候需要使用的方法
用户名异步校验
1:创建表和数据库:
2:设计一个注册页面
3:在用户名的文本框中使用onblur事件触发一个函数.
4:使用JQ的AJAX完成异步操作,将文本框的值传入到Servlet中.
5:Servlet中根据传入的用户名去数据库进行查询.
6:查询到了说明用户名已经被占用,没有查询到说明用户名可以使用.
作者: AsusCoder    时间: 2018-6-15 00:38
曾耀峰

web开发中的监听器的概述
什么是监听器:
   监听器:就是一个Java类,用来监听其他的Java的状态的变化

web中的监听器
    WEB中的Listener 和Filter是属于Servlet规范中的高级的技术

该监听器的应用:
1.加载框架的配置文件
2.定时任务调度:
1).半夜去别人的网站获取资源
2).腾讯给用户发生日邮件
   Timer



ServletCo'ntext对象的创建和销毁
  创建:服务器启动的时候, 服务器为每个web项目创建一块空间,随处可以存取。作用范围是整个项目应用
  销毁:服务器关闭的时候

3.ServletRequestListener:监听Request对象的创建和销毁的

【request对象何时创建和销毁】
只要有一次请求,就会创建request对象
譬如:访问servlet,jsp,html文件都是一次请求,会创建request对象
销毁:响应结束


第三类:
javaBean在session中要序列化对象,因为可能被序列化到硬盘
钝化:序列化
活化:反序列化

实体类Bean:Serializial序列化接口


-----优化Session;
*通过配置<Context>标签配置定时session序列化
    *在tomcat/conf/context.xml中配置<Context>
    *在tomcat/conf/Catalina/localhost/context.xml配置<Context>
    *在当前的工程下的META-INF/context.xml配置<Context>
   

Session的优化具体内容:
假如1000人创建了购物车,并不购买。占用了内存资源。这时候,设置1分钟保存在硬盘中。这时候用户再来访问,会带来SessionID,在配置文件中 directory路径下找。找到了sessionID后,就活化这个Session
作者: AsusCoder    时间: 2018-6-15 00:39
新知识集合:
xhr.onReadyStateChange 开始监听
xhr.readyState 监听器状态
4:表示请求成功
xhr.status 响应的状态码

一、传统ajax:
>get方式请求
1.传统方式的ajax_get():
//1.创建异步对象
var xhr = createXMLHttp();
//2.设置状态改变的监听
xhr.onReadyStateChange= function()
{
        //获取请求状态,4代表成功。
        if(xhr.readyState == 4)
        {
                //获得响应状态码
                if(xhr.status == 200)
                {
                                       
                }
        }

}
//3.设置请求路径
xhr.open("GET","",true);
//4.发送请求
xhr.send(null);

//这里的函数直接拷贝
//主要原因是判断不同浏览器创建的异步对象方式不一样
function createXMLHttp()
{
}

注意了,如果js是写在jsp页面中的,可以直接使用EL表达式
单独写一个文件就不可以使用EL


//Servlet向浏览器打印中文的时候,要写中文编码转换:
response.setContentType("text/html;charset='UTF-8'");
尽管接收上来的参数正确显示中文,但是输出还是要设置编码的。

>post方式提交请求:
方式和get差不多,只是请求时要设置一个请求头
1.创建异步对象
var xhr = createXMLHttp();
2.设置请求监听方法
xhr.onreadyStateChange=function()
{
        //发送请求成功
        if(xhr.readyState==4)
        {
                //响应成功
                if(xhr.status == 200)
                {
                        document.getElementById("id1").innerHTML = xhr.reponseText;
                }
               
        }
}
3.//设置请求方式
xhr.open("POST","Servlet路径",true);
4.设置请求头,避免参数传空
xhr.setRequestHeader("ContentType","这一串只要在form表单中 打印一个属性enctype就能显示,不用记住");
5.设置参数
xhr.send(username=aaa&password=123);


二、异步校验表单
1.创建表和数据库
2.设置一个注册页面
3.在用户名的文本框中使用onblur失去焦点事件触发一个函数
4.函数里使用AJAX异步操作
5.Servlet根据传入的用户名去数据库中进行查询
6.查询到了说明用户名已经被占用,没有查询到说明用户名可以使用


作者: 黄志彬    时间: 2018-6-15 01:31
黄志彬


AJAX最大优点:
        能在不刷新整个页面的前提下与服务器通信维护数据。
        避免了在网络上发送那些没有改变的信息,按需取数据,减少用户等待时间。
        不需要打断用户的操作,具有更加迅速的响应能力。
        减少不必要的数据传输、时间及降低网络上数据流量。

JSON逐步代替XML数据传递的格式。

XMLHttpRequest:
属性
*onreadystatechange:当XMLHttpRequest状态改变的时候出发一个函数
*readyState:XMLHttpRequest的状态
   0 请求未初始化(在调用 open() 之前)
  1 请求已提出(调用 send() 之前)
  2 请求已发送(这里通常可以从响应得到内容头部)
  3 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
  4 请求已完成(可以访问服务器响应并使用它)
*status:获得响应状态码。200.404....
*responseText 获得响应的文本数据
*responseXML:获得响应的xml数据


方法:
*open(请求方式,请求路径,是否异步):异步去向服务器发送请求
*send(请求参数):发送请求
*setRequestHeader(头信息,头的值):处理post请求方式的中文问题
作者: 六道的骸6    时间: 2018-6-15 08:41
张裕
Ajax 异步的 JavaScript And XML 老的技术 新的思想
        异步:和服务器互动时不会中断浏览器的连接
        服务器返回的数据会在页面局部进行刷新        用户体验较好
        同步:和服务器互动时会产生空白期 用户体验差

Ajax主要用于网页的异步 目前大范围使用的技术
        旧版的由于代码过于臃肿 重复性太高 被JQuery中的Ajax替代
       
操作步骤:
        1: 创建异步对象
        2: 设置对象状态改变触发函数
        3: 设置向后台提交的路径
        4: 发送请求
       
        jq对象.load(url,参数,回调函数)                 可以将读取到的数据写入到指定的jq对象中
        $.get(url,参数,回调函数,数据类型)        get提交参数  可在回调函数中接收返回的参数进行操作
        $.post(url,参数,回调函数,数据类型)        post提交参数

        回调函数:服务器响应回来后调用的函数
                function(data){}   data为返回的数据

        按钮变灰        attr("disabled",boolean) 设置不可用属性

最近都是代码 靠练 理论知识少
作者: Eclipse启动.    时间: 2018-6-15 16:49
郑阳阳
AJAX是一个可以向服务器异步发送请求的技术,使用老技术,新思想.
同步与异步:
同步就是点击链接或者提交数据页面才会跳转,整个页面都会刷新.
刷新过程中页面空白,用户体验全无.
异步是点击链接或者提交数据只有局部的页面会进行刷新,
用户可以浏览其余部位的页面,不会中断用户体验.
使用JQ可以更简单的使用AJAX:
jq对象.load(路径,参数,回调函数)
$.get(路径,参数,回调函数,数据类型)
$.post(路径,参数,回调函数,数据类型)
$.ajax();一般不使用,和直接使用AJAX差不多
serialize(); JQ的AJAX传递参数是需要使用
作者: LittleSky    时间: 2018-6-15 21:34
常小天
今天的学习了一样新的东西——AJAX。这是一种将老技术与新思想结合的产物。AJAX的基础是我们之前学习的js。AJAX最独特的功能就是实现异步访问服务器。所谓异步就是在不刷新当前页面的情况下向服务器发送请求,服务器响应后将响应的内容刷新到当前页面的一部分中。AJAX能够实现这一功能的基础是它有一个异步对象XMLHttpRequest。这个对象能够异步的访问服务器,它又一个属性readyState可以标识它的状态。0表示未初始化,1表示初始化,2表示发送数据,3表示数据传输中,4表示响应完成。而它的另一个属性onreadystatechange可以在它的属性发生变化时触发一个函数。要事项异步访问时,我们先创建一个异步对象,创建的方法直接引用。然后设置状态改变的监听,利用的就是onreadystatechange属性,触发方法,在方法中获得异步对象的状态和响应的状态码。当响应完成,也就是异步对象状态为4,并且响应状态码为200时,就可以接收响应回的数据。responseText获得响应的文本数据。 responseXML获得响应的XML的数据。最后利用js的选择器和写入方法将获得的数据写入到指定的区域内。这里post传递方法与get类似,只多了一步操作,就是在设置一个头信息:xhr.setRequestHeader("Content-Type", "application /x-www -form-urlencoded")。这就是AJAX实现异步的原理。而我们还进一步学习了AJAX与jQuery结合使用的方法,$.get(路径,参数,回调函数,数据类型)和 $.post(路径,参数,回调函数,数据类型)两个方法使我们的代码大大简化。
作者: 李思贤126    时间: 2018-6-15 23:30
李思贤:今天了解了同步和异步的区别
同步:就是你提交一个请求的时候,你不能浏览页面上的其他地方,只能在哪里等着
异步:就是你提交一个请求的时候,他会帮你调用一个XMLHttpRequest对象帮你去完成,而你还可以在页面上浏览其他的东西
XMLHttpRequest对象里许多的属性和方法

属性:
onreadystatechange : 指定当readyState状态改变时触发一个函数.
readyState : 返回当前请求的状态,0(未初始化)  1(初始化)  2(发送数据)  3(数据传输中)  4(完成)
responseText :将响应信息作为字符串返回  
responseXML:将响应信息格式化为Xml Document对象并返回
status : 返回当前请求的http状态码. 如200 302 304...

方法:
open( ); 创建一个新的http请求,并指定此请求的方法、URL以及验证信息(用户名/密码)

JQuery的AJAX部分方法:
Jq的对象.load(路径,参数,回调函数);
$.get(路径,参数,回调函数,数据类型);
$.post(路径,参数,回调函数,数据类型);

今天主要学习了Jquery的AJAX完成用户名是否存在的案例,和完成仿百度的案例.

用户名是否存在的案例,要求输入用户名,鼠标从文本框移开,就检验该用户名是否已被注册,并显示在页面上.

首先我们在regist.jsp中引入两个js,一个Jquery的JS,一个自己写的(放在Jquery后面),可以先在用户名标签后面放一个<span>用来显示错误信息,异步操作,鼠标从用户名文本框移开,触发一个onblue事件,在regist.js页中,我们有load和get/post方法,用load方法的话Servlet中直接输出文字在span中,想要再做其他操作很麻烦,所以这里推荐get/post方法:
$(function() {
        $("#username").blur(function() {
                var username = $(this).val();
                //load方法;
                //$("#s1").load("/Day0612/RegistServlet",{"username":username});
               
                //get 或post提交
                $.get("/Day0612/RegistServlet",{"username":username},function(data){
                        if(data==1){
                                $("#s1").html("<font color='green'>可以使用</font>");
                                $("#regbut").attr("disabled",false);
                        }else if(data==2){
                                $("#s1").html("<font color='red'>已被占用</font>");
                                $("#regbut").attr("disabled",true);
                        }
                });
        });
});


使用JQ的AJAX完成仿百度的案例:
【步骤一:】设计一个商品的搜索页面.
做一个Search.jsp,让内容居中显示.引入一个JQ的JS 一个自己的
【步骤二:】keyup事件触发一个函数.
$(function() {
        $("#word").keyup(function() {
                // 获得文本框的值:
                var word =$(this).val();
// 异步发送请求:
                $.post("/Day0612/searchServlet",{"word":word},function(data){
                        if(word!=""){
                                //alert(data);
                                $("#d1").show().html(data);
                        }else{
                                $("#d1").hide();
                        }
                });
        });
});
【步骤三:】获得文本框的值,提交到Servlet中
根据获得的文本框的值
【步骤四:】在Servlet中根据提交名称查询相应信息.(显示5个)
在业务层模糊查询得到一个数组,转发给info.jsp在info.jsp中用JSTL遍历,拿到每一个值
【步骤五:】提前在JSP中文本框下面加个DIV用来放这些数据,刚开始要设置不隐藏,确定格式后设置为隐藏,有值时显现,当值为空时也让他隐藏.这样我们就完成了黑马一下
if(word!=""){
                                //alert(data);
                                $("#d1").show().html(data);
                                }else{
                                $("#d1").hide();
                                        }

作者: 偏离X    时间: 2018-6-16 08:55
郭明杰:
[AJAX]异步的Javacript and xml
        *使用新思想,老技术
AJAX的功能:完成页面的局部刷新,不中断用户的体验

[XMLHttp]
属性:
当XMLHttpRequest状态改变的时候触发 onreadystatechange 函数
status  :获得响应的状态吗 :200,302 404 500
responseText :获得响应的文本数据
responseXML :获得响应的XML的数据

方法:
open:(请求方式,请求路径.是否异步) 异步去想服务器发送请求
send :发送请求
setRequestHeader:(头信息,头的值) :处理POST请求方式的中文问题


[AJAX]
        *第一步:创建一个异步对象.
        *第二步:设置对象状态改变触发一个函数
        *第三步:设置向后台提交的路径       
        *第四步:发送请求


[JQuery中的AJAX]:
JQuery的AJAX部分方法:
*Jq的对象.load(路径,参数,回调函数);
*$.get(路径,参数,数据类型);
*$.post(路径,参数,数据类型);
*$.ajax()
作者: Do1    时间: 2018-6-16 14:43
本帖最后由 Do1 于 2021-6-21 08:16 编辑


JQuery是精简js的一种封装工具,它使我们能够更方便的提取处理页面中的元素,ajax是一种异步同步请求,底层用的是轮循也就是说ajax会一直去访问服务器有没有新的消息,有的话传递,对服务器的资源消耗较大

今天学习的是通过jq+json+ajax完成从数据库中提取省市联动的案例,具体实现是:

通过JQ语句,点击到select框的时候触发ajax函数,请求给Servlet类,返回到的数据库数据通过json字符串处理工具提取出来

json需导包


作者: 小白47    时间: 2018-6-16 18:34
吴俊斌
ajax基本入门
     基本分为四部:创建对象  将创建对象的方法封装到方法里,触发方法
                  设置当对象状态改变的方法 对象.onreadystatechange=function()
                   通过对象.status方法  0表示对象还没创建 1表示对象已经创建
     2send表示发送数据 3,表示数据传送中 4表示完成
                   设置请求路径,  对象.open() 方式 路径 true
                   将数据提交到服务器
我们一般用的比较多的是Jq加alax
      使用流程
         通过先写个页面加载事件($(function(){})),通过选择器找到文本框添加一个
      触发事件,获取文本框的值.如果是get就调用$.get是post就调用$.post方法,同样
      传地址,参数,和一个函数,函数里的参数就是服务器传过来的数据
      
作者: wpwing    时间: 2018-6-17 16:42
吴鹏

总结

同步和异步:
同步:当点击按钮或提交时,整个页面都会刷新等待处理;
异步:通过第三个对象,实现页面局部提交请求,局部刷新,不用整个页面刷新,可以继续浏览网页;

AJAX的功能:实现页面局部刷新,不中断用户体验;
    早期JS不受重视,后台经常将其当成是一种玩具式语言;
    JS中有一个对象XMLHttpRequest,可以向服务器异步发送请求,
    传统的B/S结构软件,所有的功能都要在服务器端编写代码(胖服务器)
    有了AJAX后,可以将部分代码写道客户端浏览器(瘦服务器);
    RIA:Rich Internet Application;

XML:使用XML作为传递数据的格式;JSON:就是键值对;

XMLHttpRequest:

readyState:XMLHttpRequest的状态;

onreadystatechange:当XMLHttpRequest状态改变时后触发一个函数;

status:获得响应的状态码;0 对象建立,但是没有调用open方法
            1 对象建立,但是没有调用send方法
            2 send已调用,但是当前的状态及http头未知;
            3 已接受部分数据,但是补全,使用下面两个对象获取时,会出错
            4 完成;

responseText:异步加载的时候,获得响应的文本数据

responseXML:获得响应的XML的数据;

方法:

open(请求方法,请求路径,是否异步)  异步去向服务器发送请求;
send(请求参数)  : 发送请求;
setRequestHeader(头信息,头的值)   处理POST请求方式的中文问题;

不同的浏览器创建该对象的方法不同:
IE:将XMLHttpRequest对象封装在ActiveXObject组件;
Fierfox  直接就可以创建XMLHttpRequest;


AJAX编写的步骤:
1 创建一个异步对象

2 设置对象状态改变时触发的函数

3 设置向后台提交的路径

4 发送请求

--------------------------------------------------------

JQuery中的AJAX
常用的方法:
JQuery的对象.load(路径,参数,回调函数);

$.get(路径,参数,回调函数,数据类型)

$.post(路径,参数,回调函数,数据类型)

$.ajax();

serialize();--JQ的AJAX传递参数的时候需要使用的方法;

--------------------------------------------------------

通过AJAX实现异步:
为了通过AJAX实现异步,需要使用一个第三者对象:XMLHttpRuquest;
通过四个步骤编写AJAX代码:1 创建一个AJAX的对象 ; 2 设置监听(ajax对象的状态发生改变时触发一个函数)
3 设置向后台提交的方式(GET或者是POST),提交的路径以及是否开启异步; 4 发送请求;
每个步骤的方法分别是:
首先,创建异步对象,使用xhr变量引用;
var xhr = ajaxHttpRequest();
1 创建XMLHttpRuquest对象(调用一个给定的方法):
function ajaxFunction(){
   var xmlHttp;
   try{ // Firefox, Opera 8.0+, Safari
        xmlHttp=new XMLHttpRequest();
    }
    catch (e){
       try{// Internet Explorer
             xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
          }
        catch (e){
          try{
             xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
          }
          catch (e){}
          }
    }

    return xmlHttp;
}

2 设置监听(当异步对象的状态发生改变时,执行的函数):
xhr.onreadystatechange()=

3 设置后台传输路径:
xhr.open(请求的方法,提交路径,是否开启异步);
4 发送请求;
xhr.send(null);对于提交方法为"GET"的,send方法括号里面为null,要提交的参数写在open()方法内,而提交方法为"POST"时,
如果有提交的参数,需要先使用.setRequestHeader("Content-type","application/x-www-form-urlencoded");然后把参数
写在send()方法内;

----------------------------------------------------------
通过jq封装后的ajax实现异步:

方法:
jQuery对象.load(url,data,callback);
使用该方法来实现异步校验用户名时,url地址写入处理表单接收用户名的servlet地址,data为传入servlet的参数,
格式为{"参数名(servlet中要接收该参数的名字)":参数名(从网页中获取参数的引用名)};
该方法实现的效果是:将参数(有的话)传入url地址中,然后将结果加载进引用该方法的对象中;

$.get(路径,参数,回调函数,数据类型);该方法已经限定提交的方法是GET类型;
$(selector).get(url,data,function(response,status,xhr),dataType);
其中;
$(selector)为jq的对象;
url为提交的路径;
data为提交时一起传过去的参数;
function(response,status,xhr)为回调函数,其中,response是请求的结果数据;status是i请求的状态,xhr包含XMLHttpRequest的对象
dataType为规定预定要服务器响应的数据类型;
使用该方法来实现用户名校验时,url地址写入处理用户名的servlet地址,传入的参数就是username,然后定义一个回调函数;
函数的内容为判断servlet里面处理完username后传过来的数据,在servlet里面已经有一个判断,内容是,根据username的
值查找在mysql中是否存在该username,不存在的话response.getWriter().print(1),存在的话,response.getWriter().print(2),
这两个就是请求后返回的数据;接下来,回到js中,判断data(请求后处理的数据)的值是1还是2,然后通过id选择器,取得
用户名后面的span标签,再通过jq的html方法,将"<font color = 'green/red'>用户名可以使用/用户名已被注册</font>"
写入到标签中;

-----------------------------------------------------------

$.post(请求路径,参数,回调函数,数据类型);
此方法用法与上面的$.get()一样,就不细说了;

------------------------------------------------------------
在上面两个方法中,还可以将提交按钮的跟用户名校验联立,实现当用户名存在时,提交按钮无法激活;
在判断data内容的语句里,在往span标签写内容的下面,可以添加一句;$("#regbut").attr("disabled",true/false);
这句代码是获取id值为regbut的标签(我们需要在jsp的提交按钮标签中先定义一个id值为regbut),将其属性设置为
"disable",后面设置开启或关闭,当用户名不存在时,设置关闭,存在时,设置开启,就能实现用户名获取和提交按钮的联动;

------------------------------------------------------------

使用jq的ajax模仿百度搜索

首先,在模仿搜索的页面里定义一个搜索栏文本框,还有<div>格子,id值设为"d1",宽度和搜索栏一样的宽度,不定义长度,
实现活动式,搜索栏文本框的id值定义为"word",在页面中引用jquery的js文件和我们自己定义的一个js文件;
先来说说异步实现模仿百度搜索文本框建议栏,在我们定义的js文件中,定义一个页面皆在函数,在里面,获得文本框的id属性
$("#word").keyup,调用keyup方法,实现当在文本框中输入完文字,键盘按键弹起时,调用一个函数,函数内容为,获得文本框
的值:$("#word").val();判断word的值是否有输入数据,若是没有输入,调用hide()方法将div格子隐藏,若是有数据输入,
则调用$.post()方法,将word数据传递到一个servlet文件中进行数据处理,将处理后的数据显示到div格子中,处理的数据是
通过mysql语句的like模糊搜索查找到的数据;传递到servlet时,我们要先获得传递过来的参数,通过方法传递参数,将word
的数据传递到dao层与数据库进行交互,在dao层中,使用"select * from 表格名 where 列名 like word%"进行模糊搜索,
将搜索到的数据封装为word对象,放入list集合中,传递回servlet中;在servlet里,我们或得到包含若干个首字为word里数据的集合,
将集合放进request域中,转发到一个空白的jsp文件;在空白的jsp文件中,我们通过jstl遍历servlet传递过来的集合;再来讲讲
为什么要传递到一个新的空白的jsp集合中,我们使用的是异步,实现局部刷新数据,在js文件中,我们请求结果的路径是servlet文件,
意思就是servlet处理后的结果要返回js中的回调函数里,这样我们就是把一个集合遍历后的结果返回到js文件里,在js文件中
再判断是否有在文本框中输入值,有的话,调用servlet,查找数据库,遍历集合,放回回调函数,回调函数通过show().html(data)方法,
将遍历的结果直接显示到格子中;




作者: 许大炮    时间: 2018-6-19 19:43
许剑鸿 webDay21

Ajax:“Asynchronous Javascript And XML” 即异步 JavaScript和XML
异步和同步的区别:
同步 在用户浏览页面时提交后在新页面刷新之前不能浏览之前的页面
异步 只刷新页面中的一部分 其它部分用户可继续浏览 提高用户体验

AJAX的编写步骤:
* 第一步:创建一个异步对象.
* 第二步:设置对象状态改变触发一个函数.
* 第三步:设置向后台提交的路径
* 第四步:发送请求.

由于AJAX实现异步代码量较多较麻烦 所以一般使用JQuery实现异步请求

url:待装入 HTML 网页网址。
data:发送至服务器的 key/value 数据。在jQuery 1.3中也可以接受一个字符串了。
callback:载入成功时回调函数。


Jq的对象.load(路径,参数,回调函数):load(url, [data], [callback])
$.get(路径,参数,回调函数,数据类型);(较常用)
$.post(路径,参数,回调函数,数据类型);(较常用)
作者: 5119    时间: 2018-6-19 19:45
游荣辉
总结
今天学习了AJAX
了解了同步和异步的区别
同步:就是你提交一个请求的时候,你不能浏览页面上的其他地方,只能在哪里等着
异步:就是你提交一个请求的时候,他会帮你调用一个XMLHttpRequest对象帮你去完成,而你还可以在页面上浏览其他的东西
XMLHttpRequest对象里许多的属性和方法
属性:
onreadystatechange : 指定当readyState属性改变时的事件处理句柄。
readyState : 返回当前请求的状态
0(未初始化)   1(初始化)   2(发送数据)    3(数据传输中)    4(完成)
responseText :将响应信息作为字符串返回.
responseXML:将响应信息格式化为Xml Document对象并返回
status : 返回当前请求的http状态码.只读 如200 302 304...
方法:
open( ); 创建一个新的http请求,并指定此请求的方法、URL以及验证信息(用户名/密码)
AJAX有固定的步骤
第一步:创建一个异步对象.
第二步:设置对象状态改变触发一个函数.
第三步:设置向后台提交的路径
第四步:发送请求.
上面的是早期的AJAX现在都是使用JQ来实现       
Jq的对象.load(路径,参数,回调函数);
$.get(路径,参数,回调函数,数据类型);
$.post(路径,参数,回调函数,数据类型);
作者: 咸鱼coder    时间: 2018-6-19 21:32
万冕

ajax:就是异步请求

同步与异步
同步就是一次性将页面的所有东西全部加载,如果页面内容量大,网速慢,就会在空白页等待特别久,非常影响客户的体验

异步就是可以在客户请求的同时,在发送一个请求去搜寻数据库,在不刷新页面的情况下,刷新页面的一部分,不会中断客户的
请求,这样就不会出现等待空白页的情况

需要掌握的是用jq来进行ajax的异步校验

ajax的特点就是他在js里写好需要触发的函数,然后能将servlet里所有打印的东西都封装进data变量中,然后识别标签或者其他的东西
在把写好的js引入到jsp中
主要格式$("#jq对象").load("/工程名/servlet",{"变量名":变量})
        $.post("/工程名/servlet",{"变量名":变量},function(data){})

需要理解的就是servlet访问转发info(遍历list的页面)之所以跳转那里,是为了打印出info里面的内容,然后让其封装进data




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2