版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
《JavaScript與jQuery網(wǎng)頁前端開發(fā)與設(shè)計-第2版》教案第13章天氣預(yù)報查詢的設(shè)計與實現(xiàn)一、教學(xué)目標(biāo):學(xué)習(xí)掌握第三方服務(wù)平臺密鑰申請和調(diào)用方法;學(xué)習(xí)掌握J(rèn)avaScript和jQuery基礎(chǔ)知識;學(xué)習(xí)掌握jQueryAJAX的用法實現(xiàn)服務(wù)器請求和回調(diào)處理。二、教學(xué)重點(diǎn)和難點(diǎn):重點(diǎn):學(xué)習(xí)掌握jQueryAJAX的用法實現(xiàn)服務(wù)器請求和回調(diào)處理;難點(diǎn):服務(wù)器請求和回調(diào)處理原理的理解。三、教學(xué)方法與手段:采取互動式教學(xué)方法,理論教學(xué)使用多媒體投影教室。四、課程簡介:本章將從零開始詳解如何調(diào)用第三方服務(wù)平臺接口制作一款天氣預(yù)報查詢程序。通過對完整項目實例的解析與實現(xiàn),提高開發(fā)者項目分析能力以及強(qiáng)化對于JavaScript和jQuery的綜合應(yīng)用能力。五、教學(xué)基本內(nèi)容:13.1案例背景探索我國的氣象歷史文脈,就一定會提到北極閣。北極閣是南京城內(nèi)的一座丘陵,又名欽天山,位于鼓樓東面,北依臺城、玄武湖,西連鼓樓崗,東連覆舟山,因劉宋時山上建立日觀臺而得名。古名“雞鳴山”,因形似雞籠又名“雞籠山”,明時“國朝于山巔置儀表,以測玄緯,名觀象臺,更名欽天山”。
北極閣氣象歷史源遠(yuǎn)流長。早在南北朝時,北極閣即建有“靈臺候樓”,用以觀天測候;明,洪武年間,在此建“觀象臺”,又名“欽天臺”,既觀氣象又觀天象;清,康熙皇帝第六次下江南,曾登臺遠(yuǎn)眺,親筆“曠觀”;民國時期,卓越的氣象、地理學(xué)家——竺可楨先生,在此創(chuàng)建中國歷史上第一個氣象研究所。我國近、現(xiàn)代一批頂級氣象學(xué)家,如涂長望、趙九章、葉篤正、陶詩言等都曾在此工作、學(xué)習(xí)過。因此,南京北極閣被海內(nèi)外氣象學(xué)界譽(yù)為中國近代氣象發(fā)祥地。新中國成立至今,北極閣一直是江蘇氣象臺所在地,是江蘇氣象業(yè)務(wù)服務(wù)中心。1999年,北極閣被國家科技部、教育部、中央宣傳部和中國科協(xié)命名為“全國青少年科技教育基地”。2000年,北極閣被南京大學(xué)選定為“產(chǎn)學(xué)科研基地”。(摘自“中國天氣網(wǎng)”/)
北極閣既見證了民族歷史的滄桑一隅,也經(jīng)歷了氣象創(chuàng)業(yè)的悠久歷程。13.2案例需求本章將綜合應(yīng)用jQueryAJAX技術(shù)開發(fā)一個天氣預(yù)報查詢頁面,用戶通過切換城市名稱可以查詢該地區(qū)當(dāng)天的天氣情況。為達(dá)到真實效果,本示例將選用一款具有氣象數(shù)據(jù)服務(wù)的免費(fèi)開源API作為AJAX請求接口。用戶可以使用下拉菜單切換城市,利用jQueryAJAX技術(shù)獲取當(dāng)前城市的一系列氣象數(shù)據(jù),最后將數(shù)據(jù)展現(xiàn)在界面上。本示例節(jié)選了四個直轄市(北京、重慶、上海和天津)的天氣數(shù)據(jù)。13.3準(zhǔn)備工作13.3.1API密鑰申請本小節(jié)主要介紹如何申請獲得開源API的密鑰。由于百度APIStore目前已經(jīng)不再提供服務(wù),因此這里選擇了可以提供全球氣象數(shù)據(jù)服務(wù)接口的和風(fēng)天氣API,其官方網(wǎng)址為/。用戶使用郵箱進(jìn)行注冊并激活后每次使用都可以免費(fèi)獲取未來三天之內(nèi)全球各地區(qū)的實時天氣,免費(fèi)接口調(diào)用流量為1000次/天、頻率為200次/分鐘,該數(shù)據(jù)基本可以滿足讀者的開發(fā)學(xué)習(xí)需求。注冊完畢之后可以訪問/#/console來查看賬號信息,用戶登陸后即可看到開發(fā)者申請到的個人認(rèn)證key,如果列表是空白的則可點(diǎn)擊“添加key”按鈕創(chuàng)建一個新的應(yīng)用key。開發(fā)者需記錄上述頁面中的個人認(rèn)證key,該信息在AJAX請求時會作為身份識別的標(biāo)識一并發(fā)送給服務(wù)器。至此,開源API的密鑰申請就已經(jīng)順利完成,讀者可以進(jìn)行下一節(jié)的學(xué)習(xí),了解如何調(diào)用API獲取氣象數(shù)據(jù)。13.3.2API調(diào)用方法免費(fèi)用戶可以調(diào)用的接口地址為:/v7/,其服務(wù)器節(jié)點(diǎn)在中國境內(nèi)。該接口地址后面追加不同的關(guān)鍵詞將獲取不同的氣象數(shù)據(jù)信息,例如alarm為天氣自然災(zāi)害預(yù)警,讀者可以訪問官方文檔/docs/api/了解各類關(guān)鍵詞的使用方法。本示例將選用關(guān)鍵詞weather/now進(jìn)行實況天氣數(shù)據(jù)的獲取。實況天氣即為當(dāng)前時間點(diǎn)的天氣狀況以及溫濕風(fēng)壓等氣象指數(shù),具體包含的數(shù)據(jù):體感溫度、實測溫度、天氣狀況、風(fēng)力、風(fēng)速、風(fēng)向、相對濕度、大氣壓強(qiáng)、降水量、能見度等。目前該接口允許查詢的城市覆蓋范圍為全球任意一個城市?;陉P(guān)鍵詞weather/now的接口具有2個必填參數(shù)和3個可選參數(shù),如下表所示。表weather接口參數(shù)一覽表參數(shù)名稱參數(shù)類型解釋location必填參數(shù)用于規(guī)定需要查詢的地區(qū)??梢蕴钊氩樵兊貐^(qū)的LocationID或經(jīng)緯度坐標(biāo)(十進(jìn)制)。例如:location=101010100(查詢地區(qū)的LocationID)location=120.343,36.088(經(jīng)緯度)key必填參數(shù)需要填入用戶的個人認(rèn)證key字符串。接口將通過該數(shù)據(jù)判斷是否為授權(quán)用戶,并可以進(jìn)一步判斷是否為付費(fèi)用戶。例如:key=123abc456dfggzip可選參數(shù)對接口進(jìn)行壓縮,可大幅節(jié)省網(wǎng)絡(luò)消耗、減少接口獲取延遲。參數(shù)的默認(rèn)值是y,表示開啟gzip。參數(shù)值改成n表示不使用壓縮。lang可選參數(shù)用于指定數(shù)據(jù)的語言版本,不添加lang參數(shù)則默認(rèn)為簡體中文。例如:lang=en需要注意的是,國內(nèi)某些特定數(shù)據(jù)(例如生活指數(shù)、空氣質(zhì)量等)不支持多語言版。unit可選參數(shù)單位選擇,公制(m)或英制(i),默認(rèn)為公制單位。例如:unit=i詳見表13-2度量衡單位一覽表。 其中與unit參數(shù)相關(guān)公制和英制單位對比如下表所示。表度量衡單位一覽表數(shù)據(jù)項公制單位英制單位溫度攝氏度℃華氏度℉風(fēng)速公里/小時km/h英里/小時mile/h能見度公里km英里mile大氣壓強(qiáng)百帕hPa百帕hPa降水量毫米mm毫米mmPM2.5微克/立方米μg/m3微克/立方米μg/m3PM10微克/立方米μg/m3微克/立方米μg/m3O3微克/立方米μg/m3微克/立方米μg/m3SO2微克/立方米μg/m3微克/立方米μg/m3CO毫克/立方米mg/m3毫克/立方米mg/m3NO2微克/立方米μg/m3微克/立方米μg/m3注:部分?jǐn)?shù)據(jù)項無論選擇何種單位均會使用公制單位。免費(fèi)用戶調(diào)用接口的常見語法格式如下:/v7/weather/now?[parameters]其中[parameters]需要替換成使用到的參數(shù),多個參數(shù)之間使用&符號隔開。例如,使用LocationID查詢上海市天氣數(shù)據(jù)的寫法如下:/v7/weather/now?location=101020100&key=1234abcd注:其中key的值1234abcd為隨機(jī)填寫的內(nèi)容,請在實際開發(fā)中將其替換為真實的個人認(rèn)證key,否則接口將無法獲取數(shù)據(jù)??梢灾苯訉⑦@段地址輸入到瀏覽器地址欄中測試數(shù)據(jù)返回結(jié)果。由圖可見,指定城市的天氣數(shù)據(jù)返回結(jié)果是json數(shù)據(jù)格式的文本內(nèi)容,其中包含的數(shù)據(jù)是以“名稱:值”的形式存放。本示例將節(jié)選實況天氣now中的部分內(nèi)容進(jìn)行處理和使用。為方便用戶查看,將返回的數(shù)據(jù)內(nèi)容整理格式后節(jié)選如下:{"code":"200","updateTime":"2021-01-12T20:36+08:00","fxLink":"http://hfx.link/2bc1","now":{"obsTime":"2021-01-12T20:04+08:00","temp":"5","feelsLike":"3","icon":"150","text":"晴","wind360":"270","windDir":"西風(fēng)","windScale":"0","windSpeed":"0","humidity":"33","precip":"0.0","pressure":"1017","vis":"15","cloud":"0","dew":"-9"},"refer":{"sources":["WeatherChina"],"license":["nocommercialuse"]}}返回的字段說明如下表所示。表實況天氣返回字段說明參數(shù)描述示例值code接口請求狀態(tài)碼,例如200表示請求成功。200updateTime當(dāng)前API的最新更新時間2021-01-12T20:36+08:00fxLink該城市的天氣預(yù)報和實況自適應(yīng)網(wǎng)頁,可嵌入網(wǎng)站或應(yīng)用http://hfx.link/2bc1now實況天氣參數(shù)描述示例值obsTime實況觀測時間2021-01-12T20:04+08:00temp溫度,默認(rèn)單位:攝氏度5feelsLike體感溫度,默認(rèn)單位:攝氏度3icon實況天氣狀況的圖標(biāo)代碼。150text實況天氣狀況的文字描述晴wind360風(fēng)向360角度270windDir風(fēng)向西風(fēng)windScale風(fēng)力0windSpeed風(fēng)速,公里/小時0humidity相對濕度33precip降水量0.0pressure大氣壓強(qiáng)1017vis能見度,默認(rèn)單位:公里15cloud云量0dew實況露點(diǎn)溫度-9refer數(shù)據(jù)來源參數(shù)描述示例值sources原始數(shù)據(jù)來源,該值有可能為空值WeatherChinalicense數(shù)據(jù)許可證(例如是免費(fèi)版、商業(yè)版)nocommercialuse其中參數(shù)code的狀態(tài)碼及錯誤碼如下表所示。表接口狀態(tài)碼及錯誤碼說明代碼說明200請求成功204請求成功,但所查詢的地區(qū)暫時沒有你需要的數(shù)據(jù)。400請求錯誤,可能包含錯誤的請求參數(shù)或缺少必選的請求參數(shù)。401認(rèn)證失敗,可能使用了錯誤的KEY、數(shù)字簽名錯誤、KEY的類型錯誤。402超過訪問次數(shù)或余額不足以支持繼續(xù)訪問服務(wù),你可以充值、升級訪問量或等待訪問量重置。403無訪問權(quán)限,可能是綁定的PackageName、BundleID、域名IP地址不一致,或者是需要額外付費(fèi)的數(shù)據(jù)。404查詢的數(shù)據(jù)或地區(qū)不存在。429超過限定的QPM(每分鐘訪問次數(shù))500無響應(yīng)或超時。如果接口無法正確獲取數(shù)據(jù)可以根據(jù)狀態(tài)碼對比上表查詢原因。用戶可以根據(jù)指定的名稱找到對應(yīng)的數(shù)據(jù)值,例如在實況天氣數(shù)據(jù)now可以查到當(dāng)前城市的溫度,對應(yīng)的字段節(jié)選如下:"temp":"5"上述代碼表示當(dāng)前城市的溫度為5攝氏度,用戶也可以自行選用其他數(shù)據(jù)(例如空氣質(zhì)量指數(shù)air/now等)完成開發(fā)練習(xí)。下一節(jié)將介紹天氣查詢界面的設(shè)計方案。13.4界面設(shè)計13.4.1整體布局設(shè)計本項目的主要內(nèi)容分為三個板塊:切換城市、天氣狀況、實況氣象數(shù)據(jù)。三個板塊內(nèi)容具體解釋如下:切換城市:使用<div>元素完成,主要包含下拉菜單元素,用戶可以自行切換城市。圖標(biāo)與天氣狀況:使用<div>元素完成,主要包含當(dāng)前城市的天氣圖標(biāo)、氣溫以及天氣狀況描述(例如晴、多云、雷陣雨等)實況氣候數(shù)據(jù):使用<table>元素完成,主要包含體感溫度、相對濕度、降水量、氣壓、能見度和風(fēng)力共計6種實時氣象數(shù)據(jù),在<table>中形成四行三列表格內(nèi)容。在HTML5中使用<div>元素將這三個版塊嵌套在內(nèi)部,相關(guān)代碼如下:1. <body>2. <!--標(biāo)題-->3. <h3>jQueryAJAX天氣預(yù)報查詢的設(shè)計與實現(xiàn)</h3>4. <!--水平線-->5. <hr>6. <!--天氣查詢版塊-->7. <divid="content">8. <!--1切換城市-->9. <divid="location">10. 切換城市(下拉菜單)11. </div>12. 13. <!--2天氣描述區(qū)域-->14. <divid="weather">15. 圖標(biāo)氣溫天氣狀況16. </div>17. 18. <!--3實況數(shù)據(jù)-->19. <tableid="now">20. <!--3-1第一行(數(shù)據(jù))-->21. <trid="line01">22. <td>1-1</td>23. <td>1-2</td>24. <td>1-3</td>25. </tr>26. <!--3-2第二行(單位名稱)-->27. <trid="line02">28. <td>2-1</td><td>2-2</td><td>2-3</td>29. </tr>30. <!--3-3第三行(數(shù)據(jù))-->31. <trid="line03">32. <td>3-1</td>33. <td>3-2</td>34. <td>3-3</td>35. </tr>36. <!--3-4第四行(單位名稱)-->37. <trid="line04">38. <td>4-1</td><td>4-2</td><td>4-3</td>39. </tr>40. </table>41. </div>42. </body>在上述代碼中,首先使用了id="content"的<div>元素包括整個天氣預(yù)報查詢版塊,在其中繼續(xù)使用<div>元素拆分成上下三個模塊,其id名稱分別為location(城市位置)、weather(天氣狀況)、以及now(實況氣象數(shù)據(jù))。本示例使用CSS外部樣式表規(guī)定頁面樣式。在本地css文件夾中創(chuàng)建weather.css文件,并在<head>首尾標(biāo)簽中聲明對CSS文件的引用。相關(guān)HTML5代碼片段如下:1. <head>2. <metacharset="utf-8">3. <title>jQueryAJAX天氣預(yù)報查詢的設(shè)計與實現(xiàn)</title>4. <linkrel="stylesheet"href="css/weather.css">5. </head>在CSS外部樣式表中首先為頁面設(shè)置整體樣式,相關(guān)CSS代碼片段如下:1. /*公共樣式*/2. body{3. text-align:center;/*文本居中*/4. background:silver;/*背景顏色灰色*/5. }接下來在CSS外部樣式表中為<div>元素設(shè)置統(tǒng)一樣式,相關(guān)CSS代碼片段如下:1. div{2. padding:10px20px;/*內(nèi)邊距上下10px左右20px*/3. border:1pxsolidred;/*1px紅色實線邊框(僅為設(shè)計時使用,最終將去掉)*/4. }然后繼續(xù)為id="content"的<div>元素設(shè)置樣式,相關(guān)CSS代碼片段如下:1. /*天氣查詢內(nèi)容區(qū)域*/2. #content{3. margin:0pxauto;/*外邊距上下0左右auto*/4. max-width:480px;/*最大寬度480px*/5. background:white;/*背景顏色白色*/6. box-shadow:15px15px10pxblack;/*右下方10px寬的黑色陰影*/7. }其中box-shadow屬性可以實現(xiàn)邊框投影效果,4個參數(shù)分別代表水平方向的偏移(向右偏移15像素)、垂直方向的偏移(向下偏移15像素)、陰影寬度(10像素)和陰影顏色(黑色),均可自定義成其他值。該屬性屬于CSS3新特性中的一種,在這里僅為美化頁面作簡單使用。繼續(xù)為id="weather"的<div>元素以及內(nèi)部氣象圖標(biāo)設(shè)置樣式,相關(guān)CSS代碼片段如下:1. /*天氣描述區(qū)域*/2. #weather{3. font-size:2em;/*2個瀏覽器默認(rèn)字符寬*/4. border:1pxsolidred;/*1px紅色實線邊框(僅為設(shè)計時使用,最終將去掉)*/5. }6. /*天氣描述區(qū)域-氣象圖標(biāo)*/7. #weatherimg{8. vertical-align:middle;/*垂直方向居中*/9. }在CSS外部樣式表中為<table>及其內(nèi)部子元素設(shè)置樣式效果,相關(guān)CSS代碼如下:1. /*表格*/2. table{3. margin:15pxauto;/*外邊距上下15px左右auto*/4. }5. /*表格-單元格*/6. td{7. padding:5px20px;/*內(nèi)邊距上下5px左右20px*/8. border:1pxsolidred;/*1px紅色實線邊框(僅為設(shè)計時使用,最終將去掉)*/9. }10. /*表格-第1、3行*/11. #line01,#line03{12. font-size:1.3em;/*1.3個瀏覽器默認(rèn)字符寬*/13. }14. /*表格-第2、4行*/15. #line02,#line04{16. color:gray;/*文字顏色灰色*/17. }接下來將分別填充每個版塊中的具體內(nèi)容。13.4.2城市切換版塊設(shè)計該版塊是id="location"的<div>元素內(nèi)部內(nèi)容,包含一個下拉菜單<select>元素。本項目以四個直轄市為例,相關(guān)HTML5代碼片段如下:1. <!--1切換城市-->2. <divid="location">3. 切換城市:4. <selectid="city">5. <optionvalue="101010100"selected>北京市</option>6. <optionvalue="101040100">重慶市</option>7. <optionvalue="101020100">上海市</option>8. <optionvalue="101030100">天津市</option>9. </select>10. </div>其中第一個<option>使用了關(guān)鍵詞selected使其處于默認(rèn)被選中狀態(tài)。開發(fā)者后續(xù)也可以根據(jù)實際需要追加更多的城市選項。此時城市切換模塊的界面設(shè)計已完成。13.4.3天氣描述版塊設(shè)計該版塊是id="weather"的<div>元素內(nèi)部內(nèi)容,從左往右依次包含圖標(biāo)、氣溫數(shù)據(jù)以及氣候描述。相關(guān)HTML5代碼片段如下:1. <!--2天氣描述區(qū)域-->2. <divid="weather">3. <!--2-1氣象圖標(biāo)-->4. <imgid="icon"src="image/icons/999.png"/>5. <!--2-2溫度-->6. <spanid="temp">0</span>℃7. <!--2-3文字描述-->8. <spanid="text">Unknown</span>9. </div>其中三個元素分別解釋如下:<imgid="icon">元素:用于顯示氣候描述對應(yīng)的天氣圖標(biāo)。圖標(biāo)素材可以自行準(zhǔn)備,也可以從和風(fēng)天氣官網(wǎng)下載(/docs/start/icons/);<spanid="temp">元素:用于顯示當(dāng)前城市的氣溫(單位:攝氏度℃);<spanid="text">元素:用于顯示當(dāng)前城市的氣候描述,例如多云、晴等。此時天氣描述模塊的界面設(shè)計已完成。當(dāng)前由于尚未使用jQueryAJAX技術(shù)獲取數(shù)據(jù),因此當(dāng)前顯示的僅為樣式效果。13.4.4實況氣象數(shù)據(jù)版塊設(shè)計該版塊是id="now"的<table>元素內(nèi)部內(nèi)容,主要包含體感溫度、相對濕度、降水量、氣壓、能見度和風(fēng)力共計6種實時氣象數(shù)據(jù)。相關(guān)HTML5代碼片段如下:1. <!--3實況數(shù)據(jù)-->2. <tableid="now">3. <!--3-1第一行(數(shù)據(jù))-->4. <trid="line01">5. <td><spanid="feelsLike">0</span>℃</td>6. <td><spanid="humidity">0</span>%</td>7. <td><spanid="precip">0</span>mm</td>8. </tr>9. <!--3-2第二行(單位名稱)-->10. <trid="line02">11. <td>體感溫度</td>12. <td>相對濕度</td>13. <td>降水量</td>14. </tr>15. <!--3-3第三行(數(shù)據(jù))-->16. <trid="line03">17. <td><spanid="pressure">0</span>hPa</td>18. <td><spanid="vis">0</span>km</td>19. <td><spanid="windScale">0</span><spanid="windDir">0</span></td>20. </tr>21. <!--3-4第四行(單位名稱)-->22. <trid="line04">23. <td>氣壓</td>24. <td>能見度</td>25. <td>風(fēng)力</td>26. </tr>27. </table>表格共計四行三列,其中第1、3兩行為實況氣象數(shù)據(jù),第2、4兩行為上一行數(shù)據(jù)對應(yīng)的文字描述。此時天氣描述模塊的界面設(shè)計已完成。當(dāng)前由于尚未使用jQueryAJAX技術(shù)獲取數(shù)據(jù),因此當(dāng)前顯示的僅為樣式效果。最后整理一下CSS外部樣式表,去掉代碼中所有設(shè)置的紅色實線邊框(border:1pxsolidred)效果。此時界面設(shè)計就正式完成。當(dāng)前由于尚未使用jQueryAJAX技術(shù)獲取數(shù)據(jù),因此當(dāng)前顯示的僅為樣式效果。下一節(jié)將介紹如何使用jQueryAJAX技術(shù)調(diào)用氣象數(shù)據(jù)API并從獲取到的數(shù)據(jù)內(nèi)容中篩選出指定的數(shù)據(jù)值。13.5天氣預(yù)報查詢的實現(xiàn)13.5.1jQueryAJAX請求接口的實現(xiàn)本示例使用外部JS文件weather.js實現(xiàn)jQuery相關(guān)代碼。在本地js文件夾中創(chuàng)建weather.js文件,并在<head>首尾標(biāo)簽中聲明對JS文件的引用。相關(guān)HTML5代碼片段如下:1. <head>2. <metacharset="utf-8">3. <title>jQueryAJAX天氣預(yù)報查詢的設(shè)計與實現(xiàn)</title>4. <linkrel="stylesheet"href="css/weather.css">5. <scriptsrc="js/jquery-1.12.3.min.js"></script>6. <scriptsrc="js/weather.js"></script>7. </head>本示例選用了jQuery$.ajax()方法進(jìn)行接口請求,并檢測是否獲取到了數(shù)據(jù)內(nèi)容。由于城市ID是動態(tài)變化,因此聲明自定義函數(shù)getWeather(cityID),根據(jù)參數(shù)cityID的不同,獲取對應(yīng)城市的氣象數(shù)據(jù)。在weather.js中使用jQuery$.ajax()方法調(diào)用免費(fèi)API獲取數(shù)據(jù)的代碼如下:1. //換成您自己的密鑰2. varkey='abcd123456換成您自己的密鑰';3. //獲取指定城市的天氣預(yù)報數(shù)據(jù)4. functiongetWeather(cityID){5. $.ajax({6. url:"/v7/weather/now?key="+key+"&location="+cityID,7. method:"GET",8. dataType:"json",9. success:function(data){10. //獲取失敗11. if(data.code!="200")return;12. //當(dāng)前氣候13. varnow=data.now;14. //更新當(dāng)前氣候相關(guān)數(shù)據(jù)15. $("#icon").attr("src","image/icons/"+now.icon+".png");//圖標(biāo)16. $("#temp").text(now.temp);//氣溫17. $("#text").text(now.text);//氣候(晴、多云等描述)18. $("#feelsLike").text(now.feelsLike);//體感溫度19. $("#humidity").text(now.humidity);//濕度20. $("#precip").text(now.precip);//降水量21. $("#pressure").text(now.pressure);//氣壓22. $("#vis").text(now.vis);//能見度23. $("#windScale").text(now.windScale);//風(fēng)力等級24. $("#windDir").text(now.windDir);//風(fēng)力方向25. }26. });27. }上述方法的返回值即為從服務(wù)器端獲取到的完整氣象數(shù)據(jù),后續(xù)需要進(jìn)行篩選使用。13.5.2根據(jù)城市查詢天氣數(shù)據(jù)的實現(xiàn)在weather.js中添加自定義函數(shù)updateInfo()用于更新頁面上的氣象數(shù)據(jù),具體jQuery代碼如下:1. //更新頁面數(shù)據(jù)2. functionupdateInfo(){3. //獲取當(dāng)前城市名稱4. varcityID=$("#city").val();5. //獲取當(dāng)前城市的全部天氣數(shù)據(jù)6. getWeather(cityID);7. }在頁面準(zhǔn)備就緒時執(zhí)行updateInfo()函數(shù),使得默認(rèn)城市的氣象數(shù)據(jù)也可以正常顯示出來。然后對下拉菜單進(jìn)行監(jiān)聽,一旦發(fā)生變化則再次執(zhí)行updateInfo()方法更新頁面數(shù)據(jù)內(nèi)容。具體jQuery代碼如下:1. //文檔準(zhǔn)備就緒2. $(document).ready(function(){3. //頁面準(zhǔn)備就緒時更新天氣數(shù)據(jù)4. updateInfo();5. //監(jiān)聽下拉菜單變化6. $("#city").change(function(){7. updateInfo();//更新頁面數(shù)據(jù)8. });9. });此時本項目就已全部完成。13.6最終效果展示由于篇幅有限,本示例在下拉菜單選項中僅添加了四個直轄市作為測試用例。開發(fā)者未來可以嘗試追加新的城市、自定義天氣圖標(biāo)、或者更改需要展示的數(shù)據(jù)內(nèi)容。13.7本章小結(jié)本章通過天氣預(yù)報查詢項目的開發(fā)練習(xí)主要學(xué)習(xí)了以下知識點(diǎn)和操作:第三方平臺的密鑰申請和API調(diào)用文檔學(xué)習(xí);jQuery中ID選擇器、類選擇器等各類選擇器的綜合應(yīng)用;jQueryDOM操作更新頁面數(shù)據(jù);jQueryajax()方法的理解與應(yīng)用。通過本章的學(xué)習(xí),讀者可以提高HTML、CSS、JavaScript與jQuery的綜合應(yīng)用能力,熟悉jQuery特效中常用的方法以及AJAX技術(shù)的使用。六、參考資料和風(fēng)天氣開發(fā)文檔:/docs/start/中國天氣網(wǎng):/《HTML5網(wǎng)頁前端設(shè)計-第2版(微課視頻版)》周文潔編著,清華大學(xué)出版社,ISBN:9787302553588《HTML5網(wǎng)頁前端設(shè)計實戰(zhàn)》周文潔編著,清華大學(xué)出版社,ISBN:9787302464686《微信小程序開發(fā)實戰(zhàn)-微課視頻版》周文潔著,清華大學(xué)出版社《JavaScript與jQuery網(wǎng)頁前端開發(fā)與設(shè)計-第2版》教案第14章思政答題程序的設(shè)計與實現(xiàn)一、教學(xué)目標(biāo):學(xué)習(xí)掌握服務(wù)器的部署和啟停;學(xué)習(xí)掌握J(rèn)SON格式文件制作題庫數(shù)據(jù)和接口的編寫;學(xué)習(xí)掌握J(rèn)avaScript和jQuery基礎(chǔ)知識;學(xué)習(xí)掌握jQueryAJAX的用法實現(xiàn)服務(wù)器請求和回調(diào)處理。二、教學(xué)重點(diǎn)和難點(diǎn):重點(diǎn):學(xué)習(xí)掌握jQueryAJAX的用法實現(xiàn)服務(wù)器請求和回調(diào)處理;難點(diǎn):JSON格式文件制作題庫數(shù)據(jù)和接口的編寫。三、教學(xué)方法與手段:采取互動式教學(xué)方法,理論教學(xué)使用多媒體投影教室。四、課程簡介:本章將從零開始詳解如何開發(fā)實現(xiàn)一個基于Windows+Apache/Nginx+PHP服務(wù)器環(huán)境的思政答題程序。通過對完整項目實例的解析與實現(xiàn),提高開發(fā)者項目分析能力以及強(qiáng)化對于JavaScript和jQuery的綜合應(yīng)用能力。五、教學(xué)基本內(nèi)容:14.1案例背景2019年1月1日由中宣部組織建設(shè)的“學(xué)習(xí)強(qiáng)國”學(xué)習(xí)平臺在全國正式上線,該平臺由PC端和手機(jī)APP端兩大終端組成,是立足全黨、面向全社會的科學(xué)理論學(xué)習(xí)陣地、思想文化聚合平臺。其中手機(jī)APP端知識答題功能深受黨員群眾一致好評,以“每日答題”、“專項答題”、“每周答題”等不同的種類提供優(yōu)質(zhì)學(xué)習(xí)內(nèi)容,幫助學(xué)習(xí)者對知識進(jìn)行復(fù)習(xí)鞏固。2022年10月16日上午10時,中國共產(chǎn)黨第二十次全國代表大會在北京人民大會堂開幕。習(xí)近平代表第十九屆中央委員會向大會作報告。報告的第五部分是“實施科教興國戰(zhàn)略,強(qiáng)化現(xiàn)代化建設(shè)人才支撐”,將其專章部署,傳遞了鮮明信號(來源:《中國遠(yuǎn)程教育》雜志網(wǎng)易號學(xué)習(xí)貫徹黨的二十大精神著力推進(jìn)教育數(shù)字化與終身學(xué)習(xí))。二十大報告指出,必須堅持科技是第一生產(chǎn)力、人才是第一資源、創(chuàng)新是第一動力,深入實施科教興國戰(zhàn)略、人才強(qiáng)國戰(zhàn)略、創(chuàng)新驅(qū)動發(fā)展戰(zhàn)略。報告強(qiáng)調(diào),“我們要堅持教育優(yōu)先發(fā)展、科技自立自強(qiáng)、人才引領(lǐng)驅(qū)動,加快建設(shè)教育強(qiáng)國、科技強(qiáng)國、人才強(qiáng)國”“建成世界上規(guī)模最大的教育體系”。其中,特別指出,要辦好人民滿意的教育。堅持以人民為中心發(fā)展教育,加快建設(shè)高質(zhì)量教育體系,發(fā)展素質(zhì)教育,促進(jìn)教育公平。推進(jìn)教育數(shù)字化,建設(shè)全民終身學(xué)習(xí)的學(xué)習(xí)型社會、學(xué)習(xí)型大國。14.2案例需求本章將綜合應(yīng)用JavaScript與jQuery技術(shù)開發(fā)一個思政答題程序,題目素材來源為黨的二十大報告內(nèi)容,主題為“‘學(xué)習(xí)黨的二十大精神’專項答題”。題庫包含判斷題、單選題和多選題三種類型,共10題,每題10分,總分為100分。用戶勾選選項進(jìn)行作答,點(diǎn)擊底部的“上一題”或“下一題”按鈕可進(jìn)行題目切換,所有已作答的題目切換返回時仍可以顯示當(dāng)時作答的歷史選項記錄。在答題過程中也可以點(diǎn)擊“查看解析”按鈕查看關(guān)鍵點(diǎn)解析,幫助答題者進(jìn)行相關(guān)知識復(fù)習(xí)回顧。答完最后一題并選擇“立即交卷“按鈕后頁面將切換到結(jié)果頁顯示最終得分,點(diǎn)擊結(jié)果頁的“重新作答”可回答答題頁重新開始新的一輪答題。14.3準(zhǔn)備工作14.3.1服務(wù)器端準(zhǔn)備本次案例我們使用PC端安裝第三方免費(fèi)的phpStudyv8.1套件來模擬服務(wù)器效果,該套件的下載安裝以及啟動步驟見第12章“12.2.1臨時服務(wù)器的搭建”。然后在服務(wù)器端的根目錄WWW下新建一個自定義目錄(例如redQuiz)作為本次項目的存放路徑,這樣后續(xù)的文件在瀏覽器中的訪問地址就是:http://localhost/redQuiz/文件名或者/redQuiz/文件名這樣服務(wù)器的部署工作就完成了。14.3.2題庫素材本小節(jié)主要介紹思政答題程序的題庫素材的制作思路以及最終需要的文件格式。根據(jù)題型、選項、分值等因素,綜合考慮每個題目需要的通用字段總結(jié)如下:id:題目序號,數(shù)字形式;type:題目類型,可以錄入文字也可以用數(shù)字來標(biāo)識,這里采用文字;question:題目,純文本;optionA:選項A的文字描述;optionB:選項B的文字描述;optionC:選項C的文字描述,判斷題無此字段;optionD:選項D的文字描述,判斷題無此字段;score:當(dāng)前題目的分值,數(shù)字形式,例如10就表示10分。answer:正確答案,如果是多選題中間用英文半角的逗號隔開,例如“A,C,D”;tips:答案解析,純文本本次案例將使用較為簡單的JSON格式文件進(jìn)行題庫的存儲,開發(fā)者若學(xué)過數(shù)據(jù)庫技術(shù)也可以自行改造使用數(shù)據(jù)庫對題庫數(shù)據(jù)進(jìn)行存儲。關(guān)于JSON格式的介紹見第12章階段案例:簡易單詞查詢中的案例分析。這里節(jié)選部分題目的JSON格式效果如下:[{"id":1, "type":"判斷題", "question":"黨的二十大報告指出,十年來,黨和國家事業(yè)取得歷史性成就、發(fā)生歷史性變革,推動我國邁上全面建設(shè)社會主義現(xiàn)代化國家新征程。", "optionA":"對", "optionB":"錯", "score":10, "answer":"A", "tips":"十年來,黨和國家事業(yè)取得歷史性成就、發(fā)生歷史性變革,推動我國邁上全面建設(shè)社會主義現(xiàn)代化國家新征程。"},{"id":2,…},{"id":3,…},…]注:上述示例題目可供參考,全套題庫數(shù)據(jù)文件見本書配套代碼包。最后,將制作好的數(shù)據(jù)存到文本文檔中并另存為UTF-8格式的JSON文件,名稱可以自定義,例如就叫做data.json。此時題庫素材就制作完成了,請在服務(wù)器端的WWW/redQuiz目錄下新建目錄api(僅為示例,也可以自定義其他目錄)并將題庫文件存放進(jìn)去等待使用。14.3.3接口制作本示例選用了php技術(shù)來制作接口文件,并自定義文件名為search.php,同樣需要UTF-8編碼格式。接口文件search.php的內(nèi)容如下:1. <?php2. //讀取客戶端請求的題目編號3. $id=$_GET['id'];4. 5. //讀取json文件6. $json_data=file_get_contents('data.json');7. //把json字符串強(qiáng)制轉(zhuǎn)為PHP數(shù)組8. $php_data=json_decode($json_data,true);9. 10. //查詢狀態(tài)標(biāo)記11. $result['status_code']=0;//0表示未查到,1表示查到了12. 13. //遍歷查單詞14. foreach($php_dataas$obj){15. //如果查到了16. if($obj['id']==$id){17. $result['status_code']=1;//更新查詢狀態(tài)標(biāo)記18. $result['question_data']=$obj;//更新查詢結(jié)果19. break;//停止遍歷20. }21. }22. 23. //返回解釋(轉(zhuǎn)成json格式傳輸)24. echojson_encode($result);25. ?>上述內(nèi)容表示根據(jù)請求參數(shù)id的取值查找data.json題庫文件,并把相同題目id編號的數(shù)據(jù)返回給客戶端。此時接口文件就制作完成了,請把search.php放在服務(wù)器端的WWW/redQuiz/api目錄下等待使用。開發(fā)者也可以先使用瀏覽器自測接口是否有效,在瀏覽器地址欄輸入:http://localhost/redQuiz/api/search.php?id=1或者/redQuiz/api/search.php?id=1如果可以看到其中的“status_code”取值為1,就說明查到了對應(yīng)的題目數(shù)據(jù)。14.4界面設(shè)計14.4.1公共樣式本示例使用CSS外部樣式表規(guī)定頁面樣式,在css文件夾中創(chuàng)建common.css文件并聲明一系列公共樣式,方便答題頁與結(jié)果頁共享。創(chuàng)建UTF-8格式的網(wǎng)頁文件RedQuiz.html和Result.html分別用于展示答題頁和結(jié)果頁,并在兩個html文件的<head>首尾標(biāo)簽中均聲明對common.css文件的引用,相關(guān)HTML5代碼片段如下:1. <head>2. <metacharset="utf-8">3. <title>思政答題平臺</title>4. <linkrel="stylesheet"href="css/common.css">此時公共樣式文件中的代碼會同時影響答題頁和結(jié)果頁的頁面效果。common.css中的代碼片段如下:1. /*一、公共樣式*/2. body{3. background-color:#f5f5f5;/*背景顏色淺灰色*/4. text-align:center;/*文本居中*/5. box-sizing:border-box;/*盒子尺寸包含邊框和內(nèi)邊距*/6. }7. /*隱藏當(dāng)前元素*/8. .hide{9. display:none;/*不顯示當(dāng)前元素*/10. }11. /*水平方向布局*/12. .flexH{13. display:flex;/*彈性布局*/14. flex-direction:row;/*水平布局*/15. }16. /*垂直方向布局*/17. .flexV{18. display:flex;/*彈性布局*/19. flex-direction:column;/*垂直布局*/20. }21. /*布局交叉方向上居中*/22. .alignCenter{23. align-items:center;/*垂直布局則水平方向居中,反之亦然*/24. }25. /*彈性布局between*/26. .flexBetween{27. justify-content:space-between;/*元素之間空一樣多,兩頭貼邊*/28. }29. /*盒子區(qū)域*/30. .box{31. width:740px;/*寬度740px*/32. background-color:white;/*背景顏色為白色*/33. border-radius:10px;/*圓角邊框效果*/34. margin:20pxauto;/*外邊距上下20px左右自動居中*/35. padding:20px30px;/*內(nèi)邊距上下20px左右30px*/36. line-height:35px;/*行高35px*/37. }38. /*紅色主題按鈕*/39. .redBtn{40. color:white;/*文字顏色為白色*/41. background-color:#890000;/*背景顏色為紅色*/42. outline:none;/*無立體輪廓*/43. border:none;/*無邊框*/44. border-radius:5px;/*圓角邊框效果*/45. padding:10px20px;/*內(nèi)邊距上下10px左右20px*/46. cursor:pointer;/*鼠標(biāo)為手指指示圖標(biāo)*/47. }48. /*段落文字*/49. p{50. text-indent:2em;/*段落首行縮進(jìn)2個字符*/51. text-align:left;/*文本左對齊*/52. }14.4.2答題頁設(shè)計1整體布局設(shè)計答題頁主要分成答題區(qū)域、查看解析區(qū)域和底部按鈕組合欄。三個區(qū)域內(nèi)容具體解釋如下:答題區(qū)域:使用<div>元素完成,主要包含狀態(tài)欄(題目類型和分值)、題目、選項。解析區(qū)域:使用<div>元素完成,主要包含“查看解析”按鈕和一段解析文本。按鈕區(qū)域:使用<div>元素完成,主要包含“上一題”、“下一題”按鈕以及中間顯示“?/10”的文本表示當(dāng)前第幾題。在RedQuiz.html中使用<divclass="box">元素將這三個區(qū)域依次呈現(xiàn)出來,相關(guān)代碼如下:1. <body>2. <!--標(biāo)題-->3. <h3>思政答題平臺</h3>4. <!--水平線-->5. <hr/>6. <!--1.答題區(qū)域-->7. <divclass="box">8. </div>9. 10. <!--2.解析區(qū)域-->11. <divclass="box">12. </div>13. 14. <!--3.按鈕區(qū)域-->15. <divclass="box">16. </div>17. </body>在上述代碼中,三個區(qū)域均使用了<divclass=”box”>元素來形成寬度為740px的圓角邊框白色盒子,其中box樣式在公共樣式表common.css中已事先聲明。此時答題頁整體布局結(jié)構(gòu)就完成了,接下來將分別填充每個區(qū)域中的具體內(nèi)容。2答題區(qū)域設(shè)計該區(qū)域是第一個<divclass="box">元素內(nèi)部內(nèi)容,包含狀態(tài)欄和題目區(qū)域。相關(guān)HTML5代碼片段如下:1. <!--1.答題區(qū)域-->2. <divclass="box">3. <!--1-1狀態(tài)欄-->4. <divclass="flexHalignCenterflexBetween">5. </div>6. <!--1-2題目區(qū)域-->7. <divclass="flexV">8. </div>9. </div>上述代碼仍然使用<div>分割了狀態(tài)欄和題目區(qū)域,并直接使用公共樣式文件中事先已聲明的flexH和flexV分別表示水平布局和垂直布局,alignCenter在這里表示垂直方向上居中,flexBetween用于將內(nèi)容拉到兩端展示。接下來填充狀態(tài)欄,相關(guān)HTML5代碼片段如下:1. <!--1-1狀態(tài)欄-->2. <divclass="flexHalignCenterflexBetween">3. <!--1-1-1題目類型-->4. <divid="type">單選題</div>5. <!--1-1-2分值-->6. <divid="score">10分</div>7. </div>由于答題頁自身的樣式不多,可以繼續(xù)寫到common.css中,這里新增一個關(guān)于題目類型樣式的美化代碼。相關(guān)CSS文件代碼片段如下:1. /*一、公共樣式(…內(nèi)容略…)*/2. 3. /*二、答題頁樣式*/4. /*題型*/5. #type{6. border-left:7pxsolid#890000;/*左側(cè)7px粗細(xì)實線紅色邊框*/7. padding-left:15px;/*內(nèi)邊距左側(cè)空15px*/8. }此時答題區(qū)域頂部的狀態(tài)欄就完成了。繼續(xù)填充題目區(qū)域,相關(guān)HTML5代碼片段如下:1. <!--1-2題目區(qū)域-->2. <divclass="flexV">3. <!--1-2-1題目-->4. <pid="question">題目。</p>5. <!--1-2-2選項表單-->6. <formid="optionForm"class="flexV">7. <!--選項A區(qū)域-->8. <!--選項B區(qū)域-->9. <!--選項C區(qū)域-->10. <!--選項D區(qū)域-->11. </form>12. </div>在題目區(qū)域內(nèi)部使用段落元素<pid=”question”>來顯示題目文本,使用表單元素<formid=”optionForm”>來顯示用于選項表單。其中<form>元素也使用了公共樣式中的聲明的flexV樣式表示垂直布局。在<form>表單內(nèi)部有最多四個選項(判斷題只有選項A和B),它們的布局結(jié)構(gòu)完全相同,以選項A為例,相關(guān)HTML5代碼如下:1. <!--選項A區(qū)域-->2. <div>3. <inputid="optionA"name="options"type="radio"value="A">4. <spanclass="optionsTxt">選項A</span>5. </div>上述代碼表示每個選項區(qū)域均使用<div>區(qū)分,其內(nèi)部均放置了<input>元素暫時用于顯示單選框和<spanclass="optionsTxt">元素用于顯示當(dāng)前選項的文本內(nèi)容。其中<input>元素的屬性name="options"取值為開發(fā)者自定義,所有選項都要用同一個name名稱以確保單選框或多選框可以分到同一組內(nèi);type="radio"表示當(dāng)前是單選框,如果后期需要改成多選框,可以使用type="checkbox";屬性id="optionA"和value="A"用于標(biāo)識當(dāng)前選項,每個選項對應(yīng)的取值不同。其余選項區(qū)域的HTML5代碼和選項A區(qū)域基本相同,這里就不再重復(fù)展示,請開發(fā)者根據(jù)上面的代碼自行補(bǔ)充完整。(提示:只需要把<input>元素中的id="optionA"和value="A"以及<span>元素中的文本“選項A”這三處里面的字母“A”分別改成對應(yīng)的選項B、C、D取值即可。)在公共樣式文件common.css中繼續(xù)追加關(guān)于表單的樣式,代碼片段如下:1. /*一、公共樣式(…內(nèi)容略…)*/2. 3. /*二、答題頁樣式*/4. (…內(nèi)容略…)5. /*表單*/6. form{7. align-items:flex-start;/*水平方向左對齊布局*/8. text-indent:2em;/*段落首行縮進(jìn)2個字符*/9. }10. /*選項*/11. input{12. display:inline-block;/*行內(nèi)塊級元素*/13. margin-right:20px;/*外邊距右側(cè)空20px*/14. }此時答題頁的答題區(qū)域就已經(jīng)設(shè)計完成,下面將介紹解析區(qū)域設(shè)計。3解析區(qū)域設(shè)計該區(qū)域是第二個<divclass="box">元素內(nèi)部內(nèi)容,包含按鈕和解析文本。相關(guān)HTML5代碼片段如下:1. <!--2.解析區(qū)域-->2. <divclass="box">3. <!--2-1“查看解析”按鈕-->4. <buttonclass="redBtn">查看解析</button>5. <!--2-2解析文本-->6. <pid="tips">答案解析。</p>7. </div>上述代碼使用按鈕元素<buttonclass="redBtn">顯示紅底白字的圓角按鈕風(fēng)格,其中redBtn是在公共樣式表中事先聲明過的樣式;段落元素<p>用于顯示答案解析的文本內(nèi)容,此時公共樣式表中事先聲明的段落樣式會直接應(yīng)用到這里,且為了方便后續(xù)定位為其配置了id="tips"屬性。此時答題頁的解析區(qū)域就已經(jīng)設(shè)計完成,下面將介紹底部按鈕區(qū)域設(shè)計。4按鈕區(qū)域設(shè)計該區(qū)域是id="btnBox"的<div>元素內(nèi)部內(nèi)容,包含兩個按鈕和中間的數(shù)字文本。相關(guān)HTML5代碼片段如下:1. <!--3.按鈕區(qū)域-->2. <divid="btnBox"class="boxflexHalignCenterflexBetween">3. <!--3-1“上一題”按鈕-->4. <buttonclass="redBtn">上一題</button>5. <!--3-2中間數(shù)字標(biāo)識-->6. <div><spanid="currentNum">1</span>/10</div>7. <!--3-3“下一題”按鈕-->8. <buttonclass="redBtn">下一題</button>9. </div>上述代碼使用按鈕元素<buttonclass="redBtn">顯示左右兩側(cè)的按鈕,其中redBtn是在公共樣式表中事先聲明過的樣式,表示紅底白字的圓角按鈕風(fēng)格;中間使用了<div>顯示數(shù)字標(biāo)識區(qū)域,其內(nèi)部格式為“1/10”表示一共10題,當(dāng)前第1題,由于當(dāng)前第幾題未來需要動態(tài)變化,這里使用<spanid="currentNum">括住當(dāng)前題號以便后續(xù)可以快速定位到此處。此時答題頁的按鈕區(qū)域就已經(jīng)設(shè)計完成,整個答題頁設(shè)計完畢。當(dāng)前由于尚未使用jQueryAJAX技術(shù)獲取題庫數(shù)據(jù),因此當(dāng)前顯示的僅為樣式效果。下一節(jié)將介紹結(jié)果頁設(shè)計。14.4.3結(jié)果頁設(shè)計結(jié)果頁主要分為分?jǐn)?shù)展示區(qū)域和按鈕區(qū)域兩個部分組成。兩個區(qū)域內(nèi)容具體解釋如下:分?jǐn)?shù)展示區(qū)域:使用<p>元素完成,并將其中數(shù)字用<span>元素括住便于定位。按鈕區(qū)域:使用<button>元素完成。在Result.html中使用<divclass="box">元素將這兩個區(qū)域嵌套在內(nèi)部呈現(xiàn)出來,相關(guān)代碼如下:1. <body>2. <!--標(biāo)題-->3. <h3>思政答題平臺</h3>4. <!--水平線-->5. <hr/>6. <!--結(jié)果展示區(qū)域-->7. <divclass="box">8. <!--分?jǐn)?shù)展示文本-->9. <p>您的分?jǐn)?shù)是<spanid="finalScore">0</span>分。</p>10. <!--“重新作答”按鈕-->11. <buttonclass="redBtn">重新作答</button>12. </div>13. </body>上述代碼使用段落元素<p>顯示分?jǐn)?shù)描述文本,并在其中使用了<spanid="finalScore">特別表示分?jǐn)?shù)數(shù)值方便未來定位和更新;按鈕元素<buttonclass="redBtn">顯示“重新作答”按鈕,其中redBtn是在公共樣式表中事先聲明過的樣式,表示紅底白字的圓角按鈕風(fēng)格;由于結(jié)果頁自身的樣式不多,可以繼續(xù)寫到common.css中,這里新增一個關(guān)于分?jǐn)?shù)數(shù)值樣式的美化代碼。相關(guān)CSS文件代碼片段如下:1. /*一、公共樣式(…內(nèi)容略…)*/2. /*二、答題頁樣式(…內(nèi)容略…)*/3. 4. /*三、結(jié)果頁樣式*/5. /*分?jǐn)?shù)文本*/6. #finalScore{7. color:#890000;/*文字顏色為紅色*/8. font-size:40px;/*字體大小*/9. font-weight:bold;/*字體加粗*/10. padding:10px;/*內(nèi)邊距10px*/11. }此時結(jié)果頁就已經(jīng)設(shè)計完成。14.5邏輯實現(xiàn)14.5.1答題頁邏輯1初始化公共參數(shù)本示例使用外部JS文件實現(xiàn)jQuery相關(guān)代碼。在js文件夾中創(chuàng)建quiz.js文件,并在RedQuiz.html文件的<head>首尾標(biāo)簽中聲明對JS文件的引用。相關(guān)HTML5代碼片段如下:1. <head>2. <metacharset="utf-8">3. <title>思政答題平臺</title>4. <linkrel="stylesheet"href="css/common.css">5. <scriptsrc="js/jquery-1.12.3.min.js"></script>6. <scriptsrc="js/quiz.js"></script>7. </head>首先進(jìn)行公共參數(shù)的聲明和初始化,quiz.js中相關(guān)代碼如下:1. //公共參數(shù)2. vartotal=10;//題目總數(shù)3. varcurrent=1;//當(dāng)前第幾題4. varquestion={};//當(dāng)前題目數(shù)據(jù)5. varanswerArr=[];//記錄每題用戶的選項與得分6. //初始化每題選項與得分7. for(vari=0;i<total;i++){8. answerArr[i]={9. score:0,10. answer:''11. };12. }上述代碼將公共參數(shù)進(jìn)行了初始化,其中answerArr是數(shù)組的形式,用于記錄答題情況,由于當(dāng)前尚未開始答題,因此先將每題的用戶得分都?xì)w零,當(dāng)用戶開始答題后再更新此數(shù)組。2請求獲取數(shù)據(jù)在quiz.js中添加自定義函數(shù)requestData()用于向服務(wù)器發(fā)出請求獲取當(dāng)前題目數(shù)據(jù):1. //更新當(dāng)前數(shù)據(jù)2. functionrequestData(){3. //使用ajax()方法調(diào)用服務(wù)器端接口獲取數(shù)據(jù)4. $.ajax({5. url:"api/search.php",6. method:"GET",7. data:{8. id:current9. },10. dataType:"json",11. success:function(data){12. //判斷是否查到了結(jié)果13. if(data.status_code==1){//查到了14. //獲取題目數(shù)據(jù)15. question=data.question_data;16. //更新題目數(shù)據(jù)17. updateQuestion();18. }else{//沒查到19. alert("Ops...沒有查到這道題目");20. }21. }22. });23. }上述代碼表示使用jQueryAJAX技術(shù)向服務(wù)器同一個目錄下的api/search.php接口文件發(fā)起請求,且請求參數(shù)id是攜帶的取值就是題號current的值。如果返回值中的status_code取值是1就表示獲取到了題目數(shù)據(jù)并將數(shù)據(jù)更新給公共參數(shù)question以便后續(xù)使用,返回值是0就表示沒有查到相關(guān)題目。在ajax()方法的成功回調(diào)函數(shù)內(nèi)更新題目用的updateQuestion()為自定義函數(shù),用于把公共參數(shù)question的數(shù)據(jù)值依次更新到頁面對應(yīng)位置上。quiz.js中相關(guān)代碼如下:1. //更新題目數(shù)據(jù)2. functionupdateQuestion(){3. //更新題型4. $("#type").text(question.type);5. //更新分值6. $("#score").text(question.score+"分");7. //更新題目8. $("#question").text(question.question);9. //更新選項10. updateOptions();11. //更新解析12. $("#tips").text(question.tips);13. //更新當(dāng)前第幾題14. $("#currentNum").text(current);15. //更新底部按鈕文字顯示16. updateBtnTxt();17. }其中大部分?jǐn)?shù)據(jù)都可以直接通過id選擇器更新文本內(nèi)容,例如題型type、分值score、題目question、解析tips等,只要字段名都對應(yīng)上即可。其中更新選項和更新底部按鈕文字顯示需要執(zhí)行的代碼內(nèi)容較多,因此不妨先分別封裝成自定義函數(shù)updateOptions()和updateBtnTxt()的形式,然后逐一補(bǔ)充完整。updateOptions()用于更新選項顯示效果,在quiz.js中代碼如下:1. //更新選項2. functionupdateOptions(){3. //清除所有選中狀態(tài)4. $("#optionForminput:checked").prop("checked",false);5. //清除所有隱藏狀態(tài)6. $("#optionForm>div").show();7. //默認(rèn)先都切換為單選框8. $("#optionForminput").attr("type","radio");9. //更新全部選項文字10. $(".optionsTxt:eq(0)").text(question.optionA);11. $(".optionsTxt:eq(1)").text(question.optionB);12. $(".optionsTxt:eq(2)").text(question.optionC);13. $(".optionsTxt:eq(3)").text(question.optionD);14. 15. //如果當(dāng)前是判斷題16. if(question.type=="判斷題"){17. //隱藏選項C和D18. $("#optionForm>div:eq(2)").hide();19. $("#optionForm>div:eq(3)").hide();20. }21. //如果當(dāng)前是多選題22. elseif(question.type=="多選題"){23. //切換為多選框24. $("#optionForminput").attr("type","checkbox");25. }26. }updateBtnTxt()用于更新底部按鈕文字顯示,例如在做最后一題時不再顯示“下一題”按鈕文字,而是改成顯示“立即交卷”,而在做第一題時不再顯示“上一題”按鈕,而是顯示“到頭了”。在quiz.js中代碼如下:1. //更新底部按鈕文字顯示2. functionupdateBtnTxt(){3. //更新按鈕顯示默認(rèn)文字4. $("#btnBoxbutton:eq(0)").text("上一題");5. $("#btnBoxbutton:eq(1)").text("下一題");6. //如果當(dāng)前是第1題7. if(current==1){8. //左側(cè)按鈕文字變更9. $("#btnBoxbutton:eq(0)").text("到頭了");10. }11. //如果當(dāng)前是最后1題12. elseif(current==total){13. //右側(cè)按鈕文字變更14. $("#btnBoxbutton:eq(1)").text("立即交卷");15. }16. }最后在頁面準(zhǔn)備就緒時也執(zhí)行requestData()函數(shù),使得題庫中第1題的數(shù)據(jù)可以正常顯示出來。quiz.js中具體jQuery代碼如下:1. //文檔準(zhǔn)備就緒2. $(document).ready(function(){3. //獲取題目4. requestData();5. });由于谷歌內(nèi)核的瀏覽器禁止跨域訪問,請將本次項目案例涉及到的html、css目錄及內(nèi)部文件、js目錄及內(nèi)部文件全部放置到服務(wù)器WWW/redQuiz目錄下,然后在瀏覽器中訪問:http://localhost/redQuiz/RedQuiz.html或/redQuiz/RedQuiz.html此時第一題就可以正確顯示出來了。由于當(dāng)前尚未實現(xiàn)“下一題”按鈕邏輯,開發(fā)者可以直接修改quiz.js中的公共參數(shù)current的初始值然后重新刷新頁面來抽查題目顯示是否正確。3顯示/隱藏答題解析修改RedQuiz.html文件,找到其中的解析區(qū)域并為其內(nèi)部的<button>按鈕追加點(diǎn)擊事件showTips(),HTML5相關(guān)代碼如下:1. <!--2.解析區(qū)域-->2. <divclass="box">3. <!--2-1“查看解析”按鈕-->4. <buttonclass="redBtn"onclick="showTips()">查看解析</button>5. <!--2-2解析文本(…代碼略…)-->6. </div>在quiz.js文件中追加自定義函數(shù)showTips(),代碼如下:1. //顯示或隱藏答題解析2. functionshowTips(){3. $("#tips").toggle();//切換元素的顯示或隱藏狀態(tài)4. }其中toggle()方法來自于jQuery技術(shù),用于切換指定元素的顯示或隱藏狀態(tài)。4切換題目修改RedQuiz.html文件,找到其中的底部按鈕區(qū)域并為其內(nèi)部的兩個<button>按鈕分別追加點(diǎn)擊事件prev()和next()用于表示切換上一題或下一題,HTML5相關(guān)代碼如下:1. <!--3.按鈕區(qū)域-->2. <divid="btnBox"class="boxflexHalignCenterflexBetween">3. <!--3-1“上一題”按鈕-->4. <buttonclass="redBtn"onclick="prev()">上一題</button>5. <!--3-2中間數(shù)字標(biāo)識(…代碼略…)-->6. <!--3-3“下一題”按鈕-->7. <buttonclass="redBtn"onclick="next()">下一題</button>8. </div>在quiz.js文件中追加自定義函數(shù)prev()實現(xiàn)切換上一題功能,代碼如下:1. //切換上一題2. functionprev(){3. //如果不是第1題4. if(current>1){5. current--;//當(dāng)前題號自減16. requestData();//重新獲取題目7. }8. }只要不是第一題就可以把當(dāng)前題號減少1然后重新獲取題目并顯示在頁面上即可。在quiz.js文件中追加自定義函數(shù)next()實現(xiàn)切換下一題功能,代碼如下:1. //切換下一題2. functionnext(){3. //如果尚未到最后一題4. if(current<total){ 5. current++;//當(dāng)前題號自增16. requestData();//重新獲取題目7. }8. }只要不是最后一題就可以把當(dāng)前題號增加1然后重新獲取題目并顯示在頁面上即可。此時就可以看到點(diǎn)擊按鈕后題目發(fā)生變化了。此時在第一題點(diǎn)擊左側(cè)按鈕或在最后一題點(diǎn)擊右側(cè)按鈕均不會有切換動作,因為兩邊題目都到頭了。但是目前還不能保留答題者已經(jīng)作答過的選項是選中狀態(tài),如果某個題目已經(jīng)選過選項但是切換到上一題或下一題再回來都得重新作答。下一節(jié)將介紹如何保留答題痕跡。5保留答題痕跡可以考慮在點(diǎn)擊切換題目按鈕時處理記錄當(dāng)前已經(jīng)選過的選項信息。在quiz.js中新增自定義函數(shù)processAnswer()用于記錄已經(jīng)作答的選項,代碼如下:1. //記錄當(dāng)前題目答案2. functionprocessAnswer(){3. //獲取當(dāng)前表單中的數(shù)據(jù)值并序列化為數(shù)組4. vararr=$("#optionForm").serializeArray();5. //預(yù)留空數(shù)組存放取值(多選題考慮)6. vara=[];7. //遍歷數(shù)組元素獲取選項值8. for(vari=0;i<arr.length;i++){9. a.push(arr[i].value);10. }11. //組合最終答案為字符串12. a=a.join();13. //記錄作答選項14. answerArr[current-1].answer=a;15. }答題者的作答結(jié)果有兩種可能:一是單選題和判斷題只有唯一選項,二是多選題可能會有多個選項被同時選擇了,因此首先對表單使用serilizeArray()方法把選中的數(shù)據(jù)值序列化為數(shù)組的形式。然后預(yù)留一個臨時變量a用于存放數(shù)組中的每個選項值,使用push()方法形成例如[“A”,”B”,”C”]這樣的數(shù)組形式,然后使用join()方法會把數(shù)組a變成一個字符串,并且中間會自動加上英文半角逗號,例如”A,B,C”的形式(注:如果是數(shù)組中只有一個元素,join()方法會直接把選項答案轉(zhuǎn)為字符串不會追加逗號,例如”A”這樣的形式。最后把答案記錄到公共參數(shù)answerArr數(shù)組中對應(yīng)元素的answer屬性中,當(dāng)前題目的數(shù)組下標(biāo)就是題號current減少1,因為數(shù)組是從0開始計數(shù)的。分別修改quiz.js中的prev()和next()函數(shù),在切換題目之前都追加上調(diào)用processAnswer()函數(shù)來記錄當(dāng)前答題者的作答痕跡,相關(guān)代碼如下:1. //切換上一題2. functionprev(){3. //處理當(dāng)前題目作答情況4. processAnswer();5. //如果不是第1題6. if(current>1){…代碼略…}7. }8. //切換下一題9. functionnext(){10. //處理當(dāng)前題目作答情況11. processAnswer();12. //如果尚未到最后一題13. if(current<total){…代碼略…}14. }在quiz.js中新增自定義函數(shù)updateChecked()用于更新答題痕跡更新已作答選項的選中顯示效果,代碼如下:1. //更新已作答選項選中效果2. funct
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 福建省莆田一中2025屆高三第一次調(diào)研測試數(shù)學(xué)試卷含解析
- 2024版版權(quán)許可使用合同for軟件產(chǎn)品2篇
- 安徽省渦陽縣第四中學(xué)2025屆高三沖刺模擬數(shù)學(xué)試卷含解析
- 河北省石家莊市行唐啟明中學(xué)2025屆高考仿真模擬英語試卷含解析
- 2024年度小區(qū)物業(yè)智能停車場服務(wù)合同范本3篇
- 2024年度廣告發(fā)布合同:社交媒體廣告發(fā)布合同(2024版)2篇
- 2024年度數(shù)據(jù)安全防護(hù)技術(shù)服務(wù)合同范本下載2篇
- 2024年度債權(quán)債務(wù)追討全案委托合同3篇
- 2024年度小麥種植戶與收購商供需對接合同3篇
- 2024年度建筑設(shè)備租賃合同范本(升級版)12篇
- 《項目管理培訓(xùn)課程》課件
- 2024秋國開《管理學(xué)基礎(chǔ)》形考任務(wù)(1234)試題及答案
- 叉車安全管理
- 制藥課程設(shè)計三廢處理
- 2025年蛇年年度營銷日歷營銷建議【2025營銷日歷】
- 企業(yè)所得稅匯算清繳申報表電子表格版(帶公式-自動計算)
- 不等式在數(shù)學(xué)問題中的應(yīng)用畢業(yè)論文
- 進(jìn)口肉類產(chǎn)品名稱HS編碼及CIQ代碼
- 基于Simulink三相橋式整流電路及其濾波器的設(shè)計
- 中國多灶性運(yùn)動神經(jīng)病診治指南2019完整版
- 橋梁工程課程設(shè)計計算書6310426554
評論
0/150
提交評論