35 jQuery對Ajax的支持

image.png

image.png
//News.java
package com.imooc.ajax;

public class News {
    private String title;
    private String date;
    private String source;
    private String content;
    public News(String title, String date, String source, String content) {
        super();
        this.title = title;
        this.date = date;
        this.source = source;
        this.content = content;
    }
    public News() {
        
    }
    public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }
    public String getDate() {
        return date;
    }
    public void setDate(String date) {
        this.date = date;
    }
    public String getSource() {
        return source;
    }
    public void setSource(String source) {
        this.source = source;
    }
    public String getContent() {
        return content;
    }
    public void setContent(String content) {
        this.content = content;
    }
    
    
}

//NewsListServlet.java
package com.imooc.ajax;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.alibaba.fastjson.JSON;

/**
 * Servlet implementation class NewsListServlet
 */
@WebServlet("/news_list")
public class NewsListServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public NewsListServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String type = request.getParameter("t");
        List newsList = new ArrayList();
        if(type != null && type.equals("pypl")) {
            newsList.add(new News("PYPL:全球編程語言排行榜5月","2018-5-1","PYPL","..."));
            newsList.add(new News("PYPL:全球編程語言排行榜6月","2018-5-1","PYPL","..."));
            newsList.add(new News("PYPL:全球編程語言排行榜7月","2018-5-1","PYPL","..."));
            newsList.add(new News("PYPL:全球編程語言排行榜8月","2018-5-1","PYPL","..."));
        }else if(type == null || type.equals("tiobe")) {
            newsList.add(new News("TIOBE:全球編程語言排行榜5月","2018-5-1","TIOBE","..."));
            newsList.add(new News("TIOBE:全球編程語言排行榜6月","2018-5-1","TIOBE","..."));
            newsList.add(new News("TIOBE:全球編程語言排行榜7月","2018-5-1","TIOBE","..."));
            newsList.add(new News("TIOBE:全球編程語言排行榜8月","2018-5-1","TIOBE","..."));
        }
        
        
        
        String json = JSON.toJSONString(newsList);
        System.out.println(json);
        response.setContentType("text/html;charset=UTF-8");
        response.getWriter().println(json);
    }

}

//jquery_news.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/jquery-3.4.1.js"></script>
<script type="text/javascript">
    $(function(){     //頁面就緒函數(shù),頁面加載完成后執(zhí)行function里面的代碼
         $.ajax({
             "url":"/Ajax/news_list",
             "type":"get",//post 依然會自動用表單傳遞參數(shù)
             "data":"t=pypl",
            //對于data多個參數(shù):
            //1."data":"t=pypl&abc=123&uu=777",
            //2."data":{"t":"pypl","abc":"123","uu":"777"},  //推薦
             "dataType":"json",//text缎罢,則不會解析為json
             "success":function(json){ //對響應的json文本自動進行解析
                console.log(json);
                for(var i=0;i<json.length;i++){
                    $("#container").append("<h1>" + json[i].title + "</h1>");//追加到指定元素中
                }    
             },
             "error":function(xmlhttp,errorText){
                 console.log(xmlhttp);
                 console.log(errorText);
                 if(xmlhttp.status == "405"){
                     alert("無效的請求方法");
                 }else if(xmlhttp.status == "404"){
                     alert("未找到URL資源");
                 }else if(xmlhttp.status == "500"){
                     alert("服務器內部錯誤卑吭,請聯(lián)系管理員");
                 }else{
                     alert("產生異常,請聯(lián)系管理員");
                 }
             }
         })
    })
</script>
</head>
<body>
    <div id="container"></div>
</body>
</html>

地址欄輸入http://localhost:8080/Ajax/jquery_news.html

一個小練習

image.png
package com.imooc.ajax;

import java.util.List;

public class Song {
    private List popMusic;
    private List classMusic;
    private List rockMusic;
    public Song() {
        
    }
    
    public Song(List popMusic, List classMusic, List rockMusic) {
        super();
        this.popMusic = popMusic;
        this.classMusic = classMusic;
        this.rockMusic = rockMusic;
    }

    public List getPopMusic() {
        return popMusic;
    }
    public void setPopMusic(List popMusic) {
        this.popMusic = popMusic;
    }
    public List getClassMusic() {
        return classMusic;
    }
    public void setClassMusic(List classMusic) {
        this.classMusic = classMusic;
    }
    public List getRockMusic() {
        return rockMusic;
    }
    public void setRockMusic(List rockMusic) {
        this.rockMusic = rockMusic;
    }
    
}

package com.imooc.ajax;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.alibaba.fastjson.JSON;

/**
 * Servlet implementation class SongServlet
 */
@WebServlet("/song")
public class SongServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public SongServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String type = request.getParameter("type");
        List<String> popList = new ArrayList();
        popList.add("稻香");
        popList.add("晴天");
        popList.add("告白氣球");
        List<String> classicList = new ArrayList();
        classicList.add("千千厥歌");
        classicList.add("傻女");
        classicList.add("七友");
        List<String> rockList = new ArrayList();
        rockList.add("一塊紅布");
        rockList.add("假行僧");
        rockList.add("新長城路上的搖滾");
        
        Song songs = new Song(popList,classicList,rockList);
        String json = null;
        if(type.equals("pop")) {
            json = JSON.toJSONString(songs.getPopMusic());
        }else if(type.equals("classic")) {
            json = JSON.toJSONString(songs.getClassMusic());
        }else if(type.equals("rock")) {
            json = JSON.toJSONString(songs.getRockMusic());
        }else {
            System.out.println("類型錯誤");
            return;
        }
        System.out.println(json);
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().println(json);
    }

}

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <input type="button" name="pop" value="流行歌曲">
    <input type="button" name="classic" value="經典歌曲">
    <input type="button" name="rock" value="搖滾歌曲">
    <div id="container"></div>
    <script type="text/javascript" src="js/jquery-3.4.1.js"></script>
    <script type="text/javascript">
        $("input[name='pop']").click(function(){
            $.ajax({
                "url":"/Ajax/song",
                "type":"get",
                "data":"type=pop",
                "dataType":"json",
                "success":function(json){
                    console.log(json);
                    $("#container").text("");
                    for(var i=0;i<json.length;i++){
                        $("#container").append("<h1>"+json[i]+"</h1>");
                    }
                }
            });
        });
        
        $("input[name='classic']").click(function(){
            $.ajax({
                "url":"/Ajax/song",
                "type":"get",
                "data":"type=classic",
                "dataType":"json",
                "success":function(json){
                    console.log(json);
                    $("#container").text("");
                    for(var i=0;i<json.length;i++){
                        $("#container").append("<h1>"+json[i]+"</h1>");
                    }
                }
            });
        });
        $("input[name='rock']").click(function(){
            $.ajax({
                "url":"/Ajax/song",
                "type":"get",
                "data":"type=rock",
                "dataType":"json",
                "success":function(json){
                    console.log(json);
                    $("#container").text("");
                    for(var i=0;i<json.length;i++){
                        $("#container").append("<h1>"+json[i]+"</h1>");
                    }
                }
            });
        });
        
    </script>
    
    
    
</body>
</html>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市禽最,隨后出現(xiàn)的幾起案子刹前,更是在濱河造成了極大的恐慌,老刑警劉巖屿愚,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件汇跨,死亡現(xiàn)場離奇詭異,居然都是意外死亡妆距,警方通過查閱死者的電腦和手機穷遂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來娱据,“玉大人蚪黑,你說我怎么就攤上這事。” “怎么了忌穿?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵抒寂,是天一觀的道長。 經常有香客問我掠剑,道長屈芜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任朴译,我火速辦了婚禮井佑,結果婚禮上,老公的妹妹穿的比我還像新娘动分。我一直安慰自己毅糟,他們只是感情好,可當我...
    茶點故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布澜公。 她就那樣靜靜地躺著姆另,像睡著了一般。 火紅的嫁衣襯著肌膚如雪坟乾。 梳的紋絲不亂的頭發(fā)上迹辐,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天,我揣著相機與錄音甚侣,去河邊找鬼明吩。 笑死,一個胖子當著我的面吹牛殷费,可吹牛的內容都是我干的印荔。 我是一名探鬼主播,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼详羡,長吁一口氣:“原來是場噩夢啊……” “哼仍律!你這毒婦竟也來了?” 一聲冷哼從身側響起实柠,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤水泉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后窒盐,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體草则,經...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年蟹漓,在試婚紗的時候發(fā)現(xiàn)自己被綠了炕横。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡葡粒,死狀恐怖看锉,靈堂內的尸體忽然破棺而出姿锭,到底是詐尸還是另有隱情,我是刑警寧澤伯铣,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布呻此,位于F島的核電站,受9級特大地震影響腔寡,放射性物質發(fā)生泄漏焚鲜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一放前、第九天 我趴在偏房一處隱蔽的房頂上張望忿磅。 院中可真熱鬧,春花似錦凭语、人聲如沸葱她。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吨些。三九已至,卻和暖如春炒辉,著一層夾襖步出監(jiān)牢的瞬間豪墅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工黔寇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留偶器,地道東北人。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓缝裤,卻偏偏與公主長得像屏轰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子憋飞,可洞房花燭夜當晚...
    茶點故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內容

  • AJAX 原生js操作ajax 1.創(chuàng)建XMLHttpRequest對象 var xhr = new XMLHtt...
    碧玉含香閱讀 3,188評論 0 7
  • 詳細解讀Jquery各Ajax函數(shù): $.get(),$.post(),$.ajax(),$.getJSON() ...
    遠方不會遠閱讀 1,026評論 0 10
  • 1. 什么是同源策略 瀏覽器限制不同源的兩個網站間腳本和文本的相互訪問霎苗,只允許訪問同源下的內容。所謂同源搀崭,就是指兩...
    熊蛋子17閱讀 684評論 1 6
  • 第一章 入門 基本功能:訪問和操作 dom 元素,控制頁面樣式猾编,對頁面的事件處理瘤睹,與ajax完美結合,有豐富的插件...
    X_Arts閱讀 1,034評論 0 2
  • 一答倡、簡歷準備 1轰传、個人技能 (1)自定義控件、UI設計瘪撇、常用動畫特效 自定義控件 ①為什么要自定義控件获茬? Andr...
    lucas777閱讀 5,190評論 2 54