【城市天气】使用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 ...
随机推荐
- [转帖]美团在Redis上踩过的一些坑-5.redis cluster遇到的一些问题
美团在Redis上踩过的一些坑-5.redis cluster遇到的一些问题 博客分类: redis 运维 redis clustercluster-node-timeoutfailover 转载请 ...
- Java异常的10个关键知识点
前言 总结了Java异常十个关键知识点,面试或者工作中都有用哦,加油. 一. 异常是什么 异常是指阻止当前方法或作用域继续执行的问题.比如你读取的文件不存在,数组越界,进行除法时,除数为0等都会导致异 ...
- mysql存储过程的函数
存储过程和函数:类似java中的方法 好处:提高代码的重用性 .简化操作.减少了和数据库连接的次数,提高了效率 含义:一组预先编译好的sql语句集合,成批处理语句 语法: 一:创建语法 create ...
- C# 连接数据库的配置方法
写在前面 在项目的开发过程中我门常常遇到会忘记数据库连接的配置的写法的尴尬处境.俗话说,好记性不如烂笔头.所以,mark一下. 1.Sqlserver数据库连接 <connectionStrin ...
- Python基础之shutil模块、random模块
1.shutil模块 shutil模块是对os模块的功能补充,包含移动.复制.打包.压缩.解压等功能. 1)shutil.copyfileobj() 复制文件内容到另一个文件,可指定大小内容,如len ...
- 浏览器解析js
网页加载js步骤 1.浏览器一边下载html网页,一边开始解析(不等下载完就解析)2.遇到<script>标签,暂停解析,网页渲染的控制权交给javascript引擎3.如果<scr ...
- axios + vue导出excel文件
(使用到了elementUI框架) <template> <el-button type="primary" size="mini" @cli ...
- HTML5中重新定义的 b 和 i 元素
HTML5强调元素的语义,而非表现.b和i元素是早期HTML遗留下来的产物,它们分别用于将文本变为粗体和斜体(那时CSS还未出现). 当时的规范建议编码人员用strong替代b,用em替代i.不过,事 ...
- 字典排序MD5生成代码
/* * Project: payment.framework * * File Created at 2017年12月23日 * * Copyright 2016 CMCC Corporation ...
- H3C 什么是漫游