配合AJAX天氣預(yù)報(bào)的webService 之a(chǎn)sp
更新時(shí)間:2007年01月31日 00:00:00 作者:
因?yàn)榘l(fā)現(xiàn)AJAX目前跨域有點(diǎn)問(wèn)題,只能在IE里面設(shè)置才可以使用,所以自己就寫了個(gè)簡(jiǎn)單ASP的webService,其實(shí)作用就是一個(gè)小偷程序,把雅虎的天氣抓了過(guò)來(lái),然后生成XML。先從這里開(kāi)始吧,以后會(huì)考慮添加數(shù)據(jù)庫(kù),這樣客戶端寫好后讀取速度就很快了。
習(xí)慣了用JS寫東西,一不小心ASP也全拿JS寫的,呵呵,有時(shí)間再改成VB。
我再鄙視他一下,F(xiàn)LASH是N年前就搞過(guò)的,時(shí)間雖然丟的有點(diǎn)長(zhǎng)了,但是在AW的幫助,慢慢就會(huì)有所起色。
總算平息了火,還算是又默默改變了一件事情。
<%@LANGUAGE="JAVASCRIPT" CODEPAGE="65001"%>
<%
Session.CodePage = "65001"
Response.contentType="text/html"
Response.Expires = 0
var N=Request("n")
var Num=Request("id")
var url="http://xml.weather.yahoo.com/forecastrss?p="+N+"&u=c&id="+Num;
var xmldoc=Server.CreateObject("Microsoft.Xmlhttp");
xmldoc.open('GET',url,false);
xmldoc.send(null);
var response = xmldoc.responseXML.documentElement;
var lastNode=response.selectNodes("http://rss/channel/lastBuildDate");
var cityNode=response.selectNodes("http://rss/channel/yweather:location");
var windNode=response.selectNodes("http://rss/channel/yweather:wind");
var atmosphereNode=response.selectNodes("http://rss/channel/yweather:atmosphere");
var astronomyNode=response.selectNodes("http://rss/channel/yweather:astronomy");
var conditionNode=response.selectNodes("http://rss/channel/item/yweather:condition");
var forecastNode=response.selectNodes("http://rss/channel/item/yweather:forecast");
var lastV=lastNode(0).firstChild.nodeValue
//編輯屬性
function attri(a,b,c){
return a(b).attributes.getNamedItem(c).value
}
var cityV=attri(cityNode,0,"city")
var chillV=attri(windNode,0,"chill")
var directionV=attri(windNode,0,"direction")
var speedV=attri(windNode,0,"speed")
var humidityV=attri(atmosphereNode,0,"humidity")
var visibilityV=attri(atmosphereNode,0,"visibility")
var sunriseV=attri(astronomyNode,0,"sunrise")
var sunsetV=attri(astronomyNode,0,"sunset")
var textV=attri(conditionNode,0,"text")
var codeV=attri(conditionNode,0,"code")
var tempV=attri(conditionNode,0,"temp")
//轉(zhuǎn)換英文為中文
var cityCH=EN2CH(cityV)
function EN2CH(obj){
if(obj=="Wuhan"){return "武漢"}
else if(obj=="Nanchang"){return "南昌"}
else if(obj=="Haikou"){return "???}
else if(obj=="Beijing"){return "北京"}
else if(obj=="Shanghai"){return "上海"}
else if(obj=="Guangzhou"){return "廣州"}
else if(obj=="Yinchuan"){return "銀川"}
else if(obj=="Zhengzhou"){return "鄭州"}
else if(obj=="Changsha"){return "長(zhǎng)沙"}
else if(obj=="Hanzhong"){return "杭州"}
else if(obj=="Hong Kong"){return "香港"}
else if(obj=="Xin'an"){return "西安"}
else if(obj=="Chengdu"){return "成都"}
else if(obj=="Qingdao"){return "青島"}
else if(obj=="Guiyang"){return "貴陽(yáng)"}
else if(obj=="Jinan"){return "濟(jì)南"}
else if(obj=="Hefei"){return "合肥"}
else if(obj=="Fuzhou"){return "福州"}
else if(obj=="Nanjing"){return "南京"}
else{return obj}
}
//風(fēng)向函數(shù)
var windCH=wind(directionV)
function wind(a){
if(a>337 && a<=360){return "北風(fēng)"};
else if(a>=0 && a<=22){return "北風(fēng)"};
else if(a>22 && a<=67){return "東北風(fēng)"};
else if(a>67 && a<=112){return "東風(fēng)"};
else if(a>112 && a<=157){return "東南風(fēng)"};
else if(a>157 && a<=202){return "南風(fēng)"};
else if(a>202 && a<=247){return "西南風(fēng)"};
else if(a>247 && a<=292){return "西風(fēng)"};
else if(a>292 && a<=337){return "西北風(fēng)"};
}
//能見(jiàn)度函數(shù)
visibility=vis(visibilityV)
function vis(a){
return a/100
}
//轉(zhuǎn)換天氣為中文
var textCH=tEN2CH(textV)
function tEN2CH(obj){
if(obj=="Clear"){return "晴朗"}
else if(obj=="Sunny"){return "晴天"}
else if(obj=="Partly Cloudy"){return "局部有云"}
else if(obj=="Mostly Clear"){return "晴"}
else if(obj=="Mostly Sunny"){return "小云"}
else if(obj=="Mostly Cloudy"){return "多云"}
else if(obj=="Cloudy"){return "云"}
else if(obj=="Sunny/Wind"){return "晴轉(zhuǎn)云"}
else if(obj=="AM Clouds/PM Sun/Wind"){return "云轉(zhuǎn)晴"}
else if(obj=="AM Showers"){return "晨雨"}
else{return obj}
}
//天氣圖片
var weaNum=weaimg(codeV)
function weaimg(obj){
return "<img src=\"http\://us\.i1\.yimg\.com/us\.yimg.com/i/us/we/52/"+obj+"\.gif\" />"
}
//星期替換
function dayEn(obj){
if(obj=="Sun"){return "星期日"}
else if(obj=="Mon"){return "星期一"}
else if(obj=="Tue"){return "星期二"}
else if(obj=="Wed"){return "星期三"}
else if(obj=="Thu"){return "星期四"}
else if(obj=="Fri"){return "星期五"}
else if(obj=="Sat"){return "星期六"}
else{return obj}
}
%>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td rowspan="6" align="center"><%=cityCH%><br />
<%=weaNum%><br />
<%=textCH%></td>
<td align="right">感覺(jué):</td>
<td align="center"><%=chillV%>°</td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">實(shí)際:</td>
<td align="center"><%=tempV%>°</td>
</tr>
<tr>
<td align="right">風(fēng)向:</td>
<td align="center"><%=windCH%></td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">風(fēng)速:</td>
<td align="center"><%=speedV%>Kph</td>
</tr>
<tr>
<td align="right">濕度:</td>
<td align="center"><%=humidityV%>%</td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">能見(jiàn)度:</td>
<td align="center"><%=visibility%>km</td>
</tr>
</table>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td colspan="2" align="center" class="time"><%=lastV%></td>
</tr>
<tr>
<td bgcolor="#FFFFCC">日出:<%=sunriseV%></td>
<td bgcolor="#FFCC00">日落:<%=sunsetV%></td>
</tr>
</table>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<%
for(var i=0; i<2; i++){
var dayV=attri(forecastNode,i,"day")
var dateV=attri(forecastNode,i,"date")
var lowV=attri(forecastNode,i,"low")
var highV=attri(forecastNode,i,"high")
var texttV=attri(forecastNode,i,"text")
var codetV=attri(forecastNode,i,"code")
var dayCH=dayEn(dayV)
var texttCH=tEN2CH(texttV)
var weabmp=weaimg(codetV)
//var weatNum=weaimg(codetV)
%>
<td align="center"><%=dayCH%><br /><%=weabmp%><br /><%=texttCH%><br />最高<%=highV%>°<br />最低<%=lowV%>°</td>
<%
}
%>
</tr>
</table>
習(xí)慣了用JS寫東西,一不小心ASP也全拿JS寫的,呵呵,有時(shí)間再改成VB。
我再鄙視他一下,F(xiàn)LASH是N年前就搞過(guò)的,時(shí)間雖然丟的有點(diǎn)長(zhǎng)了,但是在AW的幫助,慢慢就會(huì)有所起色。
總算平息了火,還算是又默默改變了一件事情。
復(fù)制代碼 代碼如下:
<%@LANGUAGE="JAVASCRIPT" CODEPAGE="65001"%>
<%
Session.CodePage = "65001"
Response.contentType="text/html"
Response.Expires = 0
var N=Request("n")
var Num=Request("id")
var url="http://xml.weather.yahoo.com/forecastrss?p="+N+"&u=c&id="+Num;
var xmldoc=Server.CreateObject("Microsoft.Xmlhttp");
xmldoc.open('GET',url,false);
xmldoc.send(null);
var response = xmldoc.responseXML.documentElement;
var lastNode=response.selectNodes("http://rss/channel/lastBuildDate");
var cityNode=response.selectNodes("http://rss/channel/yweather:location");
var windNode=response.selectNodes("http://rss/channel/yweather:wind");
var atmosphereNode=response.selectNodes("http://rss/channel/yweather:atmosphere");
var astronomyNode=response.selectNodes("http://rss/channel/yweather:astronomy");
var conditionNode=response.selectNodes("http://rss/channel/item/yweather:condition");
var forecastNode=response.selectNodes("http://rss/channel/item/yweather:forecast");
var lastV=lastNode(0).firstChild.nodeValue
//編輯屬性
function attri(a,b,c){
return a(b).attributes.getNamedItem(c).value
}
var cityV=attri(cityNode,0,"city")
var chillV=attri(windNode,0,"chill")
var directionV=attri(windNode,0,"direction")
var speedV=attri(windNode,0,"speed")
var humidityV=attri(atmosphereNode,0,"humidity")
var visibilityV=attri(atmosphereNode,0,"visibility")
var sunriseV=attri(astronomyNode,0,"sunrise")
var sunsetV=attri(astronomyNode,0,"sunset")
var textV=attri(conditionNode,0,"text")
var codeV=attri(conditionNode,0,"code")
var tempV=attri(conditionNode,0,"temp")
//轉(zhuǎn)換英文為中文
var cityCH=EN2CH(cityV)
function EN2CH(obj){
if(obj=="Wuhan"){return "武漢"}
else if(obj=="Nanchang"){return "南昌"}
else if(obj=="Haikou"){return "???}
else if(obj=="Beijing"){return "北京"}
else if(obj=="Shanghai"){return "上海"}
else if(obj=="Guangzhou"){return "廣州"}
else if(obj=="Yinchuan"){return "銀川"}
else if(obj=="Zhengzhou"){return "鄭州"}
else if(obj=="Changsha"){return "長(zhǎng)沙"}
else if(obj=="Hanzhong"){return "杭州"}
else if(obj=="Hong Kong"){return "香港"}
else if(obj=="Xin'an"){return "西安"}
else if(obj=="Chengdu"){return "成都"}
else if(obj=="Qingdao"){return "青島"}
else if(obj=="Guiyang"){return "貴陽(yáng)"}
else if(obj=="Jinan"){return "濟(jì)南"}
else if(obj=="Hefei"){return "合肥"}
else if(obj=="Fuzhou"){return "福州"}
else if(obj=="Nanjing"){return "南京"}
else{return obj}
}
//風(fēng)向函數(shù)
var windCH=wind(directionV)
function wind(a){
if(a>337 && a<=360){return "北風(fēng)"};
else if(a>=0 && a<=22){return "北風(fēng)"};
else if(a>22 && a<=67){return "東北風(fēng)"};
else if(a>67 && a<=112){return "東風(fēng)"};
else if(a>112 && a<=157){return "東南風(fēng)"};
else if(a>157 && a<=202){return "南風(fēng)"};
else if(a>202 && a<=247){return "西南風(fēng)"};
else if(a>247 && a<=292){return "西風(fēng)"};
else if(a>292 && a<=337){return "西北風(fēng)"};
}
//能見(jiàn)度函數(shù)
visibility=vis(visibilityV)
function vis(a){
return a/100
}
//轉(zhuǎn)換天氣為中文
var textCH=tEN2CH(textV)
function tEN2CH(obj){
if(obj=="Clear"){return "晴朗"}
else if(obj=="Sunny"){return "晴天"}
else if(obj=="Partly Cloudy"){return "局部有云"}
else if(obj=="Mostly Clear"){return "晴"}
else if(obj=="Mostly Sunny"){return "小云"}
else if(obj=="Mostly Cloudy"){return "多云"}
else if(obj=="Cloudy"){return "云"}
else if(obj=="Sunny/Wind"){return "晴轉(zhuǎn)云"}
else if(obj=="AM Clouds/PM Sun/Wind"){return "云轉(zhuǎn)晴"}
else if(obj=="AM Showers"){return "晨雨"}
else{return obj}
}
//天氣圖片
var weaNum=weaimg(codeV)
function weaimg(obj){
return "<img src=\"http\://us\.i1\.yimg\.com/us\.yimg.com/i/us/we/52/"+obj+"\.gif\" />"
}
//星期替換
function dayEn(obj){
if(obj=="Sun"){return "星期日"}
else if(obj=="Mon"){return "星期一"}
else if(obj=="Tue"){return "星期二"}
else if(obj=="Wed"){return "星期三"}
else if(obj=="Thu"){return "星期四"}
else if(obj=="Fri"){return "星期五"}
else if(obj=="Sat"){return "星期六"}
else{return obj}
}
%>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td rowspan="6" align="center"><%=cityCH%><br />
<%=weaNum%><br />
<%=textCH%></td>
<td align="right">感覺(jué):</td>
<td align="center"><%=chillV%>°</td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">實(shí)際:</td>
<td align="center"><%=tempV%>°</td>
</tr>
<tr>
<td align="right">風(fēng)向:</td>
<td align="center"><%=windCH%></td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">風(fēng)速:</td>
<td align="center"><%=speedV%>Kph</td>
</tr>
<tr>
<td align="right">濕度:</td>
<td align="center"><%=humidityV%>%</td>
</tr>
<tr style="background-color:#E6F5FF">
<td align="right">能見(jiàn)度:</td>
<td align="center"><%=visibility%>km</td>
</tr>
</table>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td colspan="2" align="center" class="time"><%=lastV%></td>
</tr>
<tr>
<td bgcolor="#FFFFCC">日出:<%=sunriseV%></td>
<td bgcolor="#FFCC00">日落:<%=sunsetV%></td>
</tr>
</table>
<table width="163" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<%
for(var i=0; i<2; i++){
var dayV=attri(forecastNode,i,"day")
var dateV=attri(forecastNode,i,"date")
var lowV=attri(forecastNode,i,"low")
var highV=attri(forecastNode,i,"high")
var texttV=attri(forecastNode,i,"text")
var codetV=attri(forecastNode,i,"code")
var dayCH=dayEn(dayV)
var texttCH=tEN2CH(texttV)
var weabmp=weaimg(codetV)
//var weatNum=weaimg(codetV)
%>
<td align="center"><%=dayCH%><br /><%=weabmp%><br /><%=texttCH%><br />最高<%=highV%>°<br />最低<%=lowV%>°</td>
<%
}
%>
</tr>
</table>
您可能感興趣的文章:
- Ajax 通過(guò)城市名獲取數(shù)據(jù)(全國(guó)天氣預(yù)報(bào)API)
- PHP Ajax JavaScript Json獲取天氣信息實(shí)現(xiàn)代碼
- PHP+AJAX無(wú)刷新實(shí)現(xiàn)返回天氣預(yù)報(bào)數(shù)據(jù)
- JS HTML5 音樂(lè)天氣播放器(Ajax獲取天氣信息)
- AJAX集天氣\IP\多國(guó)語(yǔ)言翻譯MP3(可同步LRC歌詞顯示)\萬(wàn)年歷查詢通
- 天楓AJAX天氣預(yù)報(bào)系統(tǒng)V1.0
- AJAX天氣預(yù)報(bào)前臺(tái)
- ajax獲取用戶所在地天氣的方法
相關(guān)文章
ajax請(qǐng)求之返回?cái)?shù)據(jù)的順序問(wèn)題分析
這篇文章主要介紹了ajax請(qǐng)求之返回?cái)?shù)據(jù)的順序問(wèn)題,結(jié)合實(shí)例形式分析了ajax請(qǐng)求返回值的排序問(wèn)題,需要的朋友可以參考下2015-12-12
AJAX入門之深入理解JavaScript中的函數(shù)
AJAX入門之深入理解JavaScript中的函數(shù)...2006-06-06
JavaScript實(shí)現(xiàn)Ajax總結(jié)
ajax應(yīng)用非常普及,ajax的優(yōu)點(diǎn)大家都知道,具體就不多說(shuō)了,其缺點(diǎn)還真不少,比如破壞瀏覽器的back功能,同一個(gè)url打開(kāi)的界面并不是完全相同,還有安全性能等方面,至于有這么多的缺點(diǎn),也阻止不了大家使用ajax的步伐,下文給大家分享javascript實(shí)現(xiàn)ajax小結(jié)吧2015-10-10
如何解決Ajax的content-download時(shí)間過(guò)慢問(wèn)題
這篇文章主要介紹了Ajax的content-download時(shí)間過(guò)慢問(wèn)題的解決方法及思考過(guò)程,本文通過(guò)事件背景,過(guò)程分析,給大家介紹的非常詳細(xì),需要的朋友參考下吧2018-04-04
AJAX實(shí)現(xiàn)指定部分頁(yè)面刷新效果
這篇文章主要為大家詳細(xì)介紹了AJAX實(shí)現(xiàn)指定部分頁(yè)面刷新效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10

