使用JavaScript制作一个简单的天气应用

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 使用JavaScript制作一个简单的天气应用

随着Web开发技术的不断发展,JavaScript已经成为前端开发中不可或缺的一部分。它不仅可以用于创建动态和交互式的用户界面,还可以用于处理各种复杂的任务,如数据验证、动态内容更新、实时通信等。以下是一个使用JavaScript来创建一个简单天气应用的示例。


首先,我们需要一个HTML页面来显示天气信息。我们可以使用一个简单的表单来让用户输入城市名称,并使用一个元素来显示天气信息。

<!DOCTYPE html>  
<html>  
<head>  
    <title>天气应用</title>  
</head>  
<body>  
    <h1>天气应用</h1>  
    <form id="weatherForm">  
        <label for="city">输入城市名称:</label>  
        <input type="text" id="city" required>  
        <button type="submit">查询天气</button>  
    </form>  
    <div id="weatherInfo"></div>  
    <script src="app.js"></script>  
</body>  
</html>

接下来,我们需要在JavaScript中编写代码来处理用户输入和查询天气信息。我们可以使用Fetch API来从天气API获取数据,并使用DOM操作来更新页面上的内容。

document.getElementById('weatherForm').addEventListener('submit', function(event) {  
    event.preventDefault(); // 阻止表单的默认提交行为  
    const cityInput = document.getElementById('city');  
    const city = cityInput.value.trim(); // 获取输入的城市名称并去除首尾空格  
    if (city === '') {  
        alert('请输入有效的城市名称!'); // 如果城市名称无效,则显示警告信息  
        return;  
    }  
    // 查询天气信息  
    fetch(`https://api.openweathermap.org/data/2.5/weather?q=${city}&appid=YOUR_API_KEY`) // 替换YOUR_API_KEY为你的API密钥  
        .then(res => res.json()) // 将响应解析为JSON格式  
        .then(data => {  
            const weatherInfo = document.getElementById('weatherInfo'); // 获取显示天气信息的元素  
            weatherInfo.innerHTML = `城市:${data.name}<br>天气:${data.weather[0].description}<br>温度:${data.main.temp}°C<br>湿度:${data.main.humidity}%`; // 更新天气信息的内容  
        })  
        .catch(error => {  
            console.error('查询天气信息失败:', error); // 如果查询失败,则显示错误信息  
        });  
});


称作为参数传递给它。然后,我们使用then方法来处理响应,将JSON格式的数据解析为JavaScript对象,并从中提取天气信息。最后,我们使用DOM操作来更新页面上的内容,显示查询到的天气信息。

在JavaScript中,Fetch API 是一种处理网络请求的新方法,它返回一个Promise对象,可以让你更方便地处理异步操作。


在这个示例中,我们使用了fetch函数来发送一个GET请求,并传递了一个URL参数,该参数包含了我们要查询的城市名称。然后,我们使用then方法来处理服务器的响应。服务器返回的数据是一个JSON格式的字符串,我们需要将它解析为JavaScript对象才能访问其中的数据。因此,我们使用另一个then方法来调用响应对象的json方法,将JSON字符串解析为JavaScript对象。


一旦我们获得了JavaScript对象,就可以从中提取天气信息。在这个示例中,我们提取了城市名称、天气描述、温度和湿度信息,并将它们格式化为一个字符串,用于更新页面上的内容。


最后,我们使用catch方法来处理可能发生的错误。如果查询天气信息失败,我们将错误信息打印到控制台中。


当用户在表单中输入城市名称并点击提交按钮时,我们的JavaScript代码将自动发送一个网络请求来查询天气信息,并将结果显示在页面上。这样,用户就可以方便地查看不同城市的天气情况了。


除了查询天气信息外,JavaScript还可以用于实现许多其他功能。例如,你可以使用JavaScript来验证用户输入、动态更新页面内容、处理用户事件、发送网络请求等等。通过结合CSS和HTML,你可以创建出各种动态和交互式的Web应用。


相关文章
|
18天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
130 2
|
4天前
|
数据可视化 JavaScript 前端开发
数据可视化进阶:D3.js在复杂数据可视化中的应用
【10月更文挑战第26天】数据可视化是将数据以图形、图表等形式呈现的过程,帮助我们理解数据和揭示趋势。D3.js(Data-Driven Documents)是一个基于JavaScript的库,使用HTML、SVG和CSS创建动态、交互式的数据可视化。它通过数据驱动文档的方式,将数据与DOM元素关联,提供高度的灵活性和定制性,适用于复杂数据的可视化任务。 示例代码展示了如何使用D3.js创建一个简单的柱状图,展示了其基本用法。D3.js的链式调用和回调函数机制使代码简洁易懂,支持复杂的布局和交互逻辑。
17 3
|
9天前
|
JavaScript 前端开发 开发者
探索JavaScript原型链:深入理解与实战应用
【10月更文挑战第21天】探索JavaScript原型链:深入理解与实战应用
18 1
|
21天前
|
JavaScript 前端开发 API
Vue.js:打造高效前端应用的最佳选择
【10月更文挑战第9天】Vue.js:打造高效前端应用的最佳选择
16 2
|
22天前
|
设计模式 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
在本文中,我们将深入探讨JavaScript中的一个重要概念——闭包。闭包是一种强大的编程工具,它允许函数记住并访问其所在作用域的变量,即使该函数在其作用域之外被调用。通过详细解析闭包的定义、创建方法以及实际应用场景,本文旨在帮助读者不仅理解闭包的理论概念,还能在实际开发中灵活运用这一技巧。
|
1天前
|
前端开发 JavaScript
JavaScript新纪元:ES6+特性深度解析与实战应用
【10月更文挑战第29天】本文深入解析ES6+的核心特性,包括箭头函数、模板字符串、解构赋值、Promise、模块化和类等,结合实战应用,展示如何利用这些新特性编写更加高效和优雅的代码。
8 0
|
18天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:原理、应用与代码演示
【10月更文挑战第12天】深入理解JavaScript中的闭包:原理、应用与代码演示
|
19天前
|
监控 JavaScript 前端开发
深入了解Vue.js:构建现代前端应用的利器
【10月更文挑战第11天】深入了解Vue.js:构建现代前端应用的利器
12 0
|
19天前
|
前端开发 JavaScript 开发者
深入了解Webpack:现代JavaScript应用的打包利器
【10月更文挑战第11天】 深入了解Webpack:现代JavaScript应用的打包利器
|
19天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript闭包:原理与应用
【10月更文挑战第11天】深入理解JavaScript闭包:原理与应用
15 0