热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用AJAX技术实现天气预报功能

index.htmlscripttypetext/javascriptlanguagejavascriptsrchttp://edu.gimoo.net/u/20010630/weather.js/scriptAHREFhttp://www.webjx.comimgsrchttp://edu.gimoo.net/u/2

  index.html


 
 
 

文章地址:用AJAX技术来实现天气预报功能 
 

天气预报 
 

 
城市:

        武汉
        南昌
        502">海口
        北京
        上海
        广州
        银川
        郑州
        长沙
        杭州
        香港
        西安
        成都
        青岛
        贵阳
        济南
        合肥
        福州
        南京
        米兰


  weather.js

// Javascript Document
function btnSty(objId,objStyle)
{
        document.getElementById(objId).style.display = objStyle
}
//提示窗口控制
function ifodis(){
        btnSty(’loadifo’,’none’);
}
function settime(a){
        setTimeout(a,1000);
}
function loadtime(){
        loadifo.innerHTML += "."
}
//XML数据绑定
var xmldoc = false;
function loadurl(n){
//生成随机数,同时限制刷新次数
        var now=new Date();
        var Num=now.valueOf();
//定义往址参数
        url = "weather.asp?n="+n+"&id="+Num;
//定义为异步传输模式
        xmldoc = false;
//Mozill,Safari等浏览器时需要创建的XMLHttp类
        if(window.XMLHttpRequest){
                xmldoc = new XMLHttpRequest();
                if(xmldoc.overrideMimeType){
                                xmldoc.overrideMimeType(’text/xml’);
                }
        }
//IE浏览器时创建的XMLHttp类
        else if(window.ActiveXObject){
                try{
                        xmldoc = new ActiveXObject("Msxml3.XMLHTTP");
                }
                catch(e){
                        try{
                                xmldoc = new ActiveXObject("Msxml2.XMLHTTP");
                        }
                        catch(e){
                                try{
                                        xmldoc = new ActiveXObject("Microsoft.XMLHTTP");
                                }
                                catch(e){}
                        }
                }
        }
//不能创建XMLHTTP类时返回
        if(! xmldoc){
                return false;
        }
//调用CheckState函数
        xmldoc.onreadystatechange = CheckState;
        xmldoc.open(’GET’,url,true);
        xmldoc.send(null);
}
//状态检测
function CheckState(){
        btnSty(’loadifo’,’’)
//收到完整的服务器响应
        if(xmldoc.readyState == 1){
                loadifo.innerHTML = "连接服务器"
                }
        else if(xmldoc.readyState == 2){
                loadifo.innerHTML = "开始加载数据"
                }
        else if(xmldoc.readyState == 3){
                loadifo.innerHTML = "正在加载数据"
                settime(loadtime)
                }
        else if(xmldoc.readyState == 4){
//HTTP服务器响应值成功
                if(xmldoc.status == 200){
//将服务器返回的字符串写到页面中ID为showdiv的区域
     loadifo.innerHTML = "加载完成"
                 var response = xmldoc.responseText;
                 settime(ifodis)
                 prolist.innerHTML = response;
                }
                else{
                        loadifo.innerHTML = "错误"+xmldoc.statusText+"请重新选择";
                }
        }
}
if (top.location != self.location)top.location=self.location; 

weather.asp

<%@LANGUAGE="Javascript" CODEPAGE="65001"%>
<%
Session.CodePage = "65001"
Response.cOntentType="application/xml"
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("//rss/channel/lastBuildDate");
var cityNode=response.selectNodes("//rss/channel/yweather:location");
var windNode=response.selectNodes("//rss/channel/yweather:wind");
var atmosphereNode=response.selectNodes("//rss/channel/yweather:atmosphere");
var astrOnomyNode=response.selectNodes("//rss/channel/yweather:astronomy");
var cOnditionNode=response.selectNodes("//rss/channel/item/yweather:condition");
var forecastNode=response.selectNodes("//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")
//转换英文为中文
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 "长沙"}
        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 "贵阳"}
        else if(obj=="Jinan"){return "济南"}
        else if(obj=="Hefei"){return "合肥"}
        else if(obj=="Fuzhou"){return "福州"}
        else if(obj=="Nanjing"){return "南京"}
        else{return obj}
}
//风向函数
var windCH=wind(directionV)
function wind(a){
        if(a>337 && a<=360){return "北风"};
        else if(a>=0 && a<=22){return "北风"};
        else if(a>22 && a<=67){return "东北风"};
        else if(a>67 && a<=112){return "东风"};
        else if(a>112 && a<=157){return "东南风"};
        else if(a>157 && a<=202){return "南风"};
        else if(a>202 && a<=247){return "西南风"};
        else if(a>247 && a<=292){return "西风"};
        else if(a>292 && a<=337){return "西北风"};
}
//能见度函数
visibility=vis(visibilityV)
function vis(a){
        return a/100
}
//转换天气为中文
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 "晴转云"}
        else if(obj=="AM Clouds/PM Sun/Wind"){return "云转晴"}
        else if(obj=="AM Showers"){return "晨雨"}
        else{return obj}
}
//天气图片
var weaNum=weaimg(codeV)
function weaimg(obj){
        return ""
}
//星期替换
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}
}
%>

  
    <%=cityCH%>
      <%=weaNum%>
      <%=textCH%>
    感觉:
    <%=chillV%>°
  
  
    实际:
    <%=tempV%>°
  
  
    风向:
    <%=windCH%>
  
  
    风速:
    <%=speedV%>Kph
  
  
    湿度:
    <%=humidityV%>%
  
  
    能见度:
    <%=visibility%>km
  


  
    <%=lastV%>
  
  
    曰出:<%=sunriseV%>
    曰落:<%=sunsetV%>
  


  
<%
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)
%>
                <%=dayCH%><%=weabmp%><%=texttCH%>最高<%=highV%>°最低<%=lowV%>°
<%
}
%>

  要想自己加天气的话,在

南昌

  后面加相同的名称,城市代码到这里找http://xml.weather.yahoo.com/要想把英文城市名换成中文的,改

else if(obj=="Nanjing"){return "南京"}


推荐阅读
  • 前言对于从事技术的人员来说ajax是这好东西,都会使用,而且乐于使用。但对于新手,开发一个ajax实例,还有是难度的,必竟对于他们这是新东西。leo开发一个简单的ajax实例,用的是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 表单提交前的最后验证:通常在表单提交前,我们必须确认用户是否都把必须填选的做了,如果没有,就不能被提交到服务器,这里我们用到表单的formname.submit()看演示,其实这个对于我们修炼道 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
  • 本文介绍了DataTables插件的官方网站以及其基本特点和使用方法,包括分页处理、数据过滤、数据排序、数据类型检测、列宽度自动适应、CSS定制样式、隐藏列等功能。同时还介绍了其易用性、可扩展性和灵活性,以及国际化和动态创建表格的功能。此外,还提供了参数初始化和延迟加载的示例代码。 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
  • XMLhttpREquest_Ajax技术总结之XmlHttpRequest
    Ajax1、 什么是ajax   ... [详细]
  • 1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ... [详细]
  • 这篇文章给大家讲解如何利用dhtmlxGantt在服务器端集成数据。脚本数据保存如果您已初始化dataProcessor,则用户或以编程方式所做的任何更改都将自动 ... [详细]
  • Itwasworkingcorrectly,butyesterdayitstartedgiving401.IhavetriedwithGooglecontactsAPI ... [详细]
  • 文章目录简介HTTP请求过程HTTP状态码含义HTTP头部信息Cookie状态管理HTTP请求方式简介HTTP协议(超文本传输协议)是用于从WWW服务 ... [详细]
  • 前端提高篇(七十):SVG基本使用、基本样式、路径path
    SVG是使用XML来描述二维图形和绘图程序的语言。SVG遵循的是xml的规范,与html5的使用有所区别SVG绘制出来的是矢量图,放大之后不会失真官方文 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
author-avatar
曾理Aiheqihao_227
这个家伙很懒,什么也没留下!
Tags | 热门标签
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有