第9章 基于JQuery的Ajax處理

1. Ajax的工作原理

Ajax 是一種在無需重新加載整個網(wǎng)頁的情況下驱证,能夠更新部分網(wǎng)頁的技術昙衅。
Ajax可以使用原生JS進行創(chuàng)建使用,但是原生JS的Ajax的瀏覽器兼容性較差煞檩。一般在工作中很少使用原生方式創(chuàng)建Ajax的代碼。在商業(yè)化項目中通常會使用第三方的JS庫中的Ajax功能來實現(xiàn)異步請求望门。

與傳統(tǒng)請求方式的比較

與傳統(tǒng)請求方式的比較

Ajax的運行原理
Ajax的運行原理

2. 利用JQuery實現(xiàn)Ajax

數(shù)據(jù)庫

假期類型表

剩余假期天數(shù)表

數(shù)據(jù)庫連接工具類略
PO類

public class AskTypePO {
    
    private int atypeid;
    private String atype;
    
    public int getAtypeid() {
        return atypeid;
    }
    public void setAtypeid(int atypeid) {
        this.atypeid = atypeid;
    }
    public String getAtype() {
        return atype;
    }
    public void setAtype(String atype) {
        this.atype = atype;
    }
}

DAO類

public class SystemDAO {
    
    public List<AskTypePO> getAskTypeList(Connection conn) throws Exception {
        String sql = "select atypeid, atype from asktype";
        PreparedStatement pst = null;
        ResultSet rs = null;
        List<AskTypePO> list = new ArrayList<AskTypePO>();
        try {
            pst = conn.prepareStatement(sql);
            rs = pst.executeQuery();
            while(rs.next()) {
                AskTypePO po = new AskTypePO();
                po.setAtypeid(rs.getInt("atypeid"));
                po.setAtype(rs.getString("atype"));
                list.add(po);
            }
            
        } catch (Exception e) {
            throw e;
        } finally {
            DBUtil.close(pst, rs);
        }
        return list;
    }
    
    public int getRestDaysByEmpidAndTypeid(Connection conn, int empid, int typeid) throws Exception {
        String sql = "select rdays from restdays where empid = ? and atypeid = ?";
        PreparedStatement pst = null;
        ResultSet rs = null;
        int r = -1;
        try {
            pst = conn.prepareStatement(sql);
            pst.setInt(1, empid);
            pst.setInt(2, typeid);
            rs = pst.executeQuery();
            while(rs.next()) {
                r = rs.getInt("rdays");
            }
            
        } catch (Exception e) {
            throw e;
        } finally {
            DBUtil.close(pst, rs);
        }
        return r;
    }
}

Service類

public class SystemService {

    private SystemDAO dao = new SystemDAO();
    
    public List<AskTypePO> getAskTypeList(){
        Connection conn = DBUtil.getConnection();
        List<AskTypePO> list = null;    
        try {
            list = dao.getAskTypeList(conn);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            DBUtil.close(conn);
        }   
        return list;    
    }
    
    public int getRestDays(int empid, int typeid){
        Connection conn = DBUtil.getConnection();
        int r = -1;
        try {
            r = dao.getRestDaysByEmpidAndTypeid(conn, empid, typeid);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            DBUtil.close(conn);
        }   
        return r;   
    }
}

Servlet類
EntryQingJiaServlet

@WebServlet("/EntryQingJiaServlet")
public class EntryQingJiaServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        request.setCharacterEncoding("utf-8");
        response.setCharacterEncoding("utf-8");
        //查詢數(shù)據(jù)庫形娇,獲得所有的請假類型
        SystemService ss = new SystemService();
        List<AskTypePO> list = ss.getAskTypeList();
        //將查詢結果放入Request作用域
        request.setAttribute("alist", list);
        request.getRequestDispatcher("/qingjia.jsp").forward(request, response);
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }
}

AjaxGetRestDaysServlet

@WebServlet("/AjaxGetRestDaysServlet")
public class AjaxGetRestDaysServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        request.setCharacterEncoding("utf-8");
        response.setCharacterEncoding("utf-8");
        
        //得到ajax提交的數(shù)據(jù)
        String t = request.getParameter("t");
        String a = request.getParameter("a");
        
        System.out.println(t);
        System.out.println(a);
        //根據(jù)數(shù)據(jù)查詢數(shù)據(jù)庫獲得結果
        SystemService ss = new SystemService();
        int r = ss.getRestDays(2, Integer.parseInt(t));

        //響應客戶端(通過out對象輸出結果)
        response.setContentType("text/plain");
        PrintWriter out = response.getWriter();
        out.println(r);
        out.flush();
        out.close();
        
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }
}

JSP
index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
    <a href="${pageContext.request.contextPath}/EntryQingJiaServlet">申請休假</a>
</body>
</html>

qingjia.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>    
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>申請休假</title>
<script src="${pageContext.request.contextPath}/js/jquery-3.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
    $(document).ready(function (){
        $("#asktype").change(function (){
            var typeid = $(this).val();
            //將typeid發(fā)給servlet
            $.ajax({
                url: "${pageContext.request.contextPath}/AjaxGetRestDaysServlet",
                data: {"t":typeid,"a":"哈哈"},
                type: "post",
                dataType: "text",
                async : true,
                error : function (XMLHttpRequest, textStatus, errorThrown){
                    alert("Ajax出錯")
                },
                success : function (data){
                    if(data == -1){
                        data = "無限制";
                    }
                    $("#days").html(data);
                }
            });
        });
    });
</script>
</head>
<body>
    休假類型:
    <select id="asktype">
        <option value="-1">=請選擇=</option>
        <c:forEach var="a" items="${alist}">
            <option value="${a.atypeid}">${a.atype}</option>
        </c:forEach>
    </select>
    <br>
    可用天數(shù):<span id="days">無限制</span>
</body>
</html>
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市筹误,隨后出現(xiàn)的幾起案子桐早,更是在濱河造成了極大的恐慌,老刑警劉巖厨剪,帶你破解...
    沈念sama閱讀 212,657評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哄酝,死亡現(xiàn)場離奇詭異,居然都是意外死亡祷膳,警方通過查閱死者的電腦和手機陶衅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,662評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來直晨,“玉大人搀军,你說我怎么就攤上這事∮禄剩” “怎么了罩句?”我有些...
    開封第一講書人閱讀 158,143評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長敛摘。 經(jīng)常有香客問我门烂,道長,這世上最難降的妖魔是什么兄淫? 我笑而不...
    開封第一講書人閱讀 56,732評論 1 284
  • 正文 為了忘掉前任屯远,我火速辦了婚禮,結果婚禮上捕虽,老公的妹妹穿的比我還像新娘慨丐。我一直安慰自己,他們只是感情好泄私,可當我...
    茶點故事閱讀 65,837評論 6 386
  • 文/花漫 我一把揭開白布咖气。 她就那樣靜靜地躺著,像睡著了一般挖滤。 火紅的嫁衣襯著肌膚如雪崩溪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,036評論 1 291
  • 那天斩松,我揣著相機與錄音伶唯,去河邊找鬼。 笑死惧盹,一個胖子當著我的面吹牛乳幸,可吹牛的內(nèi)容都是我干的瞪讼。 我是一名探鬼主播,決...
    沈念sama閱讀 39,126評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼粹断,長吁一口氣:“原來是場噩夢啊……” “哼符欠!你這毒婦竟也來了?” 一聲冷哼從身側響起瓶埋,我...
    開封第一講書人閱讀 37,868評論 0 268
  • 序言:老撾萬榮一對情侶失蹤希柿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后养筒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體曾撤,經(jīng)...
    沈念sama閱讀 44,315評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,641評論 2 327
  • 正文 我和宋清朗相戀三年晕粪,在試婚紗的時候發(fā)現(xiàn)自己被綠了挤悉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,773評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡巫湘,死狀恐怖装悲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情尚氛,我是刑警寧澤诀诊,帶...
    沈念sama閱讀 34,470評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站怠褐,受9級特大地震影響畏梆,放射性物質發(fā)生泄漏您宪。R本人自食惡果不足惜奈懒,卻給世界環(huán)境...
    茶點故事閱讀 40,126評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宪巨。 院中可真熱鬧磷杏,春花似錦、人聲如沸捏卓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,859評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽怠晴。三九已至遥金,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蒜田,已是汗流浹背稿械。 一陣腳步聲響...
    開封第一講書人閱讀 32,095評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留冲粤,地道東北人美莫。 一個月前我還...
    沈念sama閱讀 46,584評論 2 362
  • 正文 我出身青樓页眯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親厢呵。 傳聞我的和親對象是個殘疾皇子窝撵,可洞房花燭夜當晚...
    茶點故事閱讀 43,676評論 2 351

推薦閱讀更多精彩內(nèi)容