【城市天气】使用Ajax发送和接受数据
任务:利用中国天气网的公开接口,实现天气预报的查询功能
实验的功能要求如下:
(1)当网页加载时,根据所给的 json 数据解析获得省(直辖市)的信息并显示在下拉列表框中供用户选择;
(2)当用户选择某个省(直辖市),在第二个下拉列表框中显示所有的城市(地区)信息;
(3)当用户选择了某个城市(地区),查询最近 15 天的天气预报信息并在表格中显示。
主要代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>天气查询</title>
<script type="text/javascript" src="citydata.js"></script> //数据比较大,无法上传
<script type="text/javascript" src="jquery-3.3.1.min.js"></script>
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<script type="text/javascript">
function getPro()
{
$("#pro").html(""); for(i=0;i<cityData.length;i++)
{
if(cityData[i].pid==0)
{
$("#pro").append('<option value="'+cityData[i].id+'">'+cityData[i].city_name+'</option>'); }
}
getCity($("#pro").val());
}
function getCity(pid)
{
$("#ThisPro").html($("#pro option:selected").text());
$("#ThisCity").html("");
$("#city").html("");
var flag=false;
for(i=0;i<cityData.length;i++)
{
if(cityData[i].pid==pid)
{
flag=true;
$("#city").append('<option value="'+cityData[i].city_code+'">'+cityData[i].city_name+'</option>');
}
}
if(!flag)
{
for(i=0;i<cityData.length;i++)
{
if(cityData[i].id==pid)
{
$("#city").append('<option value="'+cityData[i].city_code+'">'+$("#pro option:selected").text()+'</option>');
break;
}
}
}
queryWeatherInfo($("#city").val());
}
function queryWeatherInfo(city_code)
{
var url="http://www.class-space.cn/weather/query?cityCode="+city_code;
$("#ThisCity").text($("#city option:selected").text());
$.get(url,function(result,status,xhr)
{
if(status=="success")
{
var forecast=result.data.forecast;
var msg="";
for(i=0;i<forecast.length;i++)
{
msg+="<tr align='center'>";
msg+="<td>"+forecast[i].ymd+"</td>";
msg+="<td>"+forecast[i].type+"</td>";
msg+="<td>"+forecast[i].low.slice(3,6)+"</td>";
msg+="<td>"+forecast[i].high.slice(3,6)+"</td>";
msg+="<td>"+forecast[i].fx+"</td>";
msg+="<td>"+forecast[i].fl+"</td>";
msg+="<td>"+forecast[i].sunrise+"</td>";
msg+="<td>"+forecast[i].notice+"</td>";
msg+="</tr>";
}
$("#WeatherLoadList").html(msg);
}
});
} </script>
</head>
<body> <div id="contain"> <p>请选择需要查询的城市或信息</p>
<br>
<div>
省(直辖市):
<select id="pro"></select>
城市(地区):
<select id="city"></select>
</div>
<hr>
<div>
<span class="lead" id="ThisPro" style="color:red;font-size:30px;"></span>
<span id="ThisCity" ></span>
</div>
<br>
<table class="table table-striped table-hover">
<thead>
<tr align="center">
<th scope="col">日期</th>
<th scope="col">天气情况</th>
<th scope="col">最低温度</th>
<th scope="col">最高温度</th>
<th scope="col">风向</th>
<th scope="col">风速</th>
<th scope="col">日出时间</th>
<th scope="col">提示</th>
</tr>
</thead>
<tbody id="WeatherLoadList"></tbody>
</table> </div>
<script>
$(document).ready(function(){
getPro();
$("#pro").change(function()
{
getCity(this.value);
}); $("#city").change(function(){
queryWeatherInfo(this.value)
});
});
</script>
</body>
</html>
【城市天气】使用Ajax发送和接受数据的更多相关文章
- JavaScript实现ajax发送表单数据
知识点: 1.重置表单数据 2.获取表单数据(纯JavaScript) 3.设置表单数据(纯JavaScript) 4.ajax发送数据到客户端 (1)设置请求头,自己组合数据 (2)实例化表单对象, ...
- NSStream实现发送和接受数据
一.基本概念在iOS中以NSStream(流)来发送和接收数据,可以设置流的代理,对流状态的变化做出相应.1连接建立2接收到数据3连接关闭NSStream:数据流的父类,用于定义抽象特性,例如:打开. ...
- XMPP框架下微信项目总结(7)聊天通信处理-发送,接受数据
前言:通其他的功能处理一样,聊天也是通过模块发起的成为:“消息模块” 原理:1 current客户端开启通过消息模块开启并监听消息(监听通过代理). 2 当“current客户端”收到来自“other ...
- 兼容ie7到ie11,edge,chrome,firefox的ajax发送接收post数据代码
/* * 生成XMLHttpRequest */ function getxhr() { //获取ajax对象 var xhr = null; try { xhr = new XDomainReque ...
- Python-定时爬取指定城市天气(一)-发送给关心的微信好友
一.背景 上班的日子总是3点一线,家里,公司和上班的路径,对于一个特别懒得我来说,经常遇到上班路上下雨了,而我却没带伞,多么痛的领悟.最近对python有一种狂热的学习热情,写了4年多的C++代码,对 ...
- Django进阶(路由系统、中间件、缓存、Cookie和Session、Ajax发送数据
路由系统 1.每个路由规则对应一个view中的函数 url(r'^index/(\d*)', views.index), url(r'^manage/(?P<name>\w*)/(?P&l ...
- Django中数据传输编码格式、ajax发送json数据、ajax发送文件、django序列化组件、ajax结合sweetalert做二次弹窗、批量增加数据
前后端传输数据的编码格式(contentType) 提交post请求的两种方式: form表单 ajax请求 前后端传输数据的编码格式 urlencoded formdata(form表单里的) ja ...
- ajax跨域访问数据
通过json发送和接受数据,数据以json的格式在服务器端和前台进行传递,什么是json数据?这里就不进行详细阐述,轻自行百度解决. 在html5 中利用ajax 异步请求时,会遇到跨域的问题,如果域 ...
- Django学习——ajax发送其他请求、上传文件(ajax和form两种方式)、ajax上传json格式、 Django内置序列化(了解)、分页器的使用
1 ajax发送其他请求 1 写在form表单 submit和button会触发提交 <form action=""> </form> 注释 2 使用inp ...
随机推荐
- 第十七节:.Net Core中新增HttpClientFactory的前世今生
一. 背景 1.前世 提到HttpClient,在传统的.Net版本中简直臭名昭著,因为我们安装官方用法 using(var httpClient = new HttpClient()),当然可以Di ...
- Lua函数声明与调用
lua编程中,我们经常也会遇到函数的声明定义和调用. [1]lua中函数定义与调用的方法 lua有两种函数定义和调用的方法(本质都是用属性,方式不同而已): (1)点号形式 (2)冒号形式 两种方法的 ...
- C语言输入单字符避免回车的四种方法
在scanf()中使用'\n'屏蔽回车符号. scanf("%d\n", &n); scanf("%c", &c); 2.在scanf()格式串 ...
- Dubbo面试踩坑
1.Dubbo支持哪些协议,每种协议的应用场景,优缺点? dubbo: 单一长连接和NIO异步通讯,适合大并发小数据量的服务调用,以及消费者远大于提供者.传输协议TCP,异步,Hessian序列化: ...
- 集成开发环境(IDE)
学习目标: 1.了解Java的IDE开发工具 2.会使用Eclipse.IDEA开发工具新建项目,编写代码,并运行程序. 学习过程: 使用文本开发效率无疑是很低的,每次编写完代码后,还需要手动的编译执 ...
- apache设置外网访问的方法 (服务器)
环境:windows server 2012 R2 apache 2.4 首先,找到apache配置文件httpd.conf,找到配置: 代码展示: <directory /> optio ...
- SQL 查询表外键_T-Sql 2016——级联删除外键查询
SELECT fk.name AS foreign_key_name, oSub.name AS table_name, SubCol.name AS table_column, oMain.name ...
- Java 最常见 200+ 面试题全解析:面试必备
本文分为十九个模块,分别是: Java 基础.容器.多线程.反射.对象拷贝.Java Web .异常.网络.设计模式.Spring/Spring MVC.Spring Boot/Spring Clou ...
- 2019-07-29 ThinkPHP简单的增删改查
在model里面,建立表名Model.class.php的控制器,用以连接数据表,代码如下 namespace Home\Model; use Think\Model; class NewsModel ...
- linux memcached 的安装
linux memcached安装yum -y install libevent libevent-deve yum list memcached yum -y install memcached m ...