您的位置是:网站首页>Javascript编程Javascript编程

教程篇:如何用JS和API制作天气Web应用程序(收藏)

少儿编程网2021-09-29 15:53:42Javascript编程 人已围观 来源:少儿编程 -用户投稿

简介之前的文章《手把教你使用HTML、CSS和JS制作随机密码生成器(分享)》中,给大家介绍了怎么使用html、css和js制作随机密码生成器。下面本篇文章给大家介绍如何用JS和API制作天气Web应用程序,我们一起看看怎么做。今天我将制作一个很棒的天气应用程序,我们可以在其中搜索任何城市、地区或国家/

之前的文章《手把教你使用HTML、CSS和JS制作随机密码生成器(分享)》中,给大家介绍了怎么使用html、css和js制作随机密码生成器。下面本篇文章给大家介绍如何用JS和API制作天气Web应用程序,我们一起看看怎么做。tv4少儿编程网-https://www.pxcodes.com

tv4少儿编程网-https://www.pxcodes.com

今天我将制作一个很棒的天气应用程序,我们可以在其中搜索任何城市、地区或国家/地区,并使用Weather API获取其当前天气。此外,为了给它添加一些修饰,我还使用了Unsplash API作为网站的背景图片,这将基于您输入的位置。我为卡片添加了倾斜效果和玻璃化外观。我们将在这个项目中使用的编程语言是HTMLCSSJS。所以让我们咕咕咕。tv4少儿编程网-https://www.pxcodes.com

看看我们将要实现的**终样子tv4少儿编程网-https://www.pxcodes.com

演示地址:https://wanghao221.github.io/Weather.io/tv4少儿编程网-https://www.pxcodes.com

bilibili展示视频:https://www.bilibili.com/video/BV1xX4y1c7Z4tv4少儿编程网-https://www.pxcodes.com

注意:我在文中只提到了您应该/可能在代码中使用的几个关键点和步骤。因为,这是一个博客,而不是代码库,所以我想保持简洁。如果您想参考整个代码地址https://github.com/wanghao221/Weather.io 去看看吧!tv4少儿编程网-https://www.pxcodes.com

第 1 步 - 设置环境并收集所有资源

使用您喜欢的代码编辑器,创建一个名为“Weather App”或任何您想要的名字,然后创建这三个文件并将这些资源添加到文件夹中:tv4少儿编程网-https://www.pxcodes.com

  • index.htmltv4少儿编程网-https://www.pxcodes.com

  • style.csstv4少儿编程网-https://www.pxcodes.com

  • script.jstv4少儿编程网-https://www.pxcodes.com

我们需要的其他资源:tv4少儿编程网-https://www.pxcodes.com

  • Favicontv4少儿编程网-https://www.pxcodes.com

  • Loading GIF (optional)tv4少儿编程网-https://www.pxcodes.com

  • Vanilla-Tilt.js filetv4少儿编程网-https://www.pxcodes.com

下载所有这些资源地址:https://download.csdn.net/download/qq_44273429/20463321tv4少儿编程网-https://www.pxcodes.com

第 2 步 - 从 index.html 开始

从HTML 文件的常用模板开始。根据需要添加标题。 tv4少儿编程网-https://www.pxcodes.com

在链接style.css和之前script.js,链接您想要的谷歌字体。我使用过Poppins字体,这是我比较喜欢的字体之一。(谷歌字体)tv4少儿编程网-https://www.pxcodes.com

HTMLtv4少儿编程网-https://www.pxcodes.com

<link
href="https://fonts.googleapis.com/css2family=Poppins:ital,wght@0,200;0,400;0,500;0,600;0,700;0,800;0,900;1,800&display=swap"
rel="stylesheet">

现在从body开始,如果您希望向您的网站添加加载程序,那么您可以将其添加到正文标签中,然后为其编写脚本。tv4少儿编程网-https://www.pxcodes.com

HTMLtv4少儿编程网-https://www.pxcodes.com

<body onl oad="myFunction()">

制作两个单独的div。一个用于heading title,一个用于卡片。在它下面添加合适的div标签。tv4少儿编程网-https://www.pxcodes.com

这里我使用了一个SVG格式的搜索按钮。您可以将此代码用于卡片div中的按钮。tv4少儿编程网-https://www.pxcodes.com

HTMLtv4少儿编程网-https://www.pxcodes.com

<button>
<svg stroke="currentColor" fill="currentColor" stroke-width="0" viewBox="0 0 16 16" height="1em"
width="1.5em" xmlns="http://www.w3.org/2000/svg">
<path fill-rule="evenodd" d="M10.442 10.442a1 1 0 011.415 0l3.85 3.85a1 1 0 01-1.414 1.415l-3.85-3.85a1 1 0 010-1.415z"
clip-rule="evenodd"></path>
<path fill-rule="evenodd" d="M6.5 12a5.5 5.5 0 100-11 5.5 5.5 0 000 11zM13 6.5a6.5 6.5 0 11-13 0 6.5 6.5 0 0113 0z"
clip-rule="evenodd"></path>
</svg>
</button>

为默认图标显示添加天气图标。tv4少儿编程网-https://www.pxcodes.com

HTMLtv4少儿编程网-https://www.pxcodes.com

<div class="flex">
  <img src="https://openweathermap.org/img/wn/04d.png" alt="" class="icon" />
  <div class="description">多云</div>
</div>

加载动画和Vanilla-Tilt js的脚本。在正文结束之前添加它。我在上面步骤 1 中提到的资源中添加了Vanilla-Tilt Js文件。tv4少儿编程网-https://www.pxcodes.com

JStv4少儿编程网-https://www.pxcodes.com

<script>
        var preloader = document.getElementById('loading');
        function myFunction() {
            preloader.style.display = 'none';
        }
</script>
<script type="text/javascript" src="js/vanilla-tilt.js"></script>
    <script type="text/javascript">
        VanillaTilt.init(document.querySelector(".card"), {
            max: 15,
            glare: true,
            reverse: true,
            "max-glare": 0.5,
            speed: 400
        });
        VanillaTilt.init(document.querySelectorAll(".card"));
</script> 

第 3 步 - 设置索引文

从样式body和其他元素开始。tv4少儿编程网-https://www.pxcodes.com

设置加载动画的样式。您可以使用此代码对其进行样式设置。由于加载动画具有白色背景,因此我使用了#fff。我在资源文件夹中添加了SVG图像。tv4少儿编程网-https://www.pxcodes.com

CSStv4少儿编程网-https://www.pxcodes.com

#loading{
  position: fixed;
  width: 100%;
  height: 100vh;
  background: #fff url('/loading.svg')
  no-repeat center;
  z-index: 99999;
}

请参阅Github存储库以获取 CSS 代码tv4少儿编程网-https://www.pxcodes.com

地址:https://github.com/wanghao221/Weather.iotv4少儿编程网-https://www.pxcodes.com

第 4 步 - 获取 Weather API 和 Unsplash API 密钥

前往OpenWeatherMap并创建一个帐户。登录后单击API Keys选项卡中的 ,您将看到API密钥。复制API Key并粘贴到下面提到的 JavaScript代码的第二行 (apiKey: " <Insert API Key here>",)tv4少儿编程网-https://www.pxcodes.com

前往Unsplash Source。在这里,您可以看到如何根据大小、文本、用户的喜好、收藏等以不同的方式调用图片。tv4少儿编程网-https://www.pxcodes.com

tv4少儿编程网-https://www.pxcodes.com

第 5 步 - 从 JavaScript 编码开始

JavaScipt中集成API对于学习如何为Web应用程序使用API至关重要。我已经列出了整个代码。你可以通过它并理解代码。tv4少儿编程网-https://www.pxcodes.com

我已将此调用"url('https://source.unsplash.com/1600x900/?city " + name + "')"用于背景图像。您可以根据需要自定义URLtv4少儿编程网-https://www.pxcodes.com

我还使用了上海市的默认天气weather.fetchWeather("Shanghai");。您可以在此处添加任何城市的名称。每当您加载网站时,都会弹出这个城市的天气。tv4少儿编程网-https://www.pxcodes.com

JS
tv4少儿编程网-https://www.pxcodes.com

let weather = {
  apiKey: "<Insert API Key here>",
  fetchWeather: function (city) {
    fetch(
      "https://api.openweathermap.org/data/2.5/weather?q=" +
        city +
        "&units=metric&appid=" +
        this.apiKey
    )
      .then((response) => response.json())
      .then((data) => this.displayWeather(data));
  },
  displayWeather: function (data) {
    const { name } = data;
    const { icon, description } = data.weather[0];
    const { temp, humidity } = data.main;
    const { speed } = data.wind;
    document.querySelector(".city").innerText = "Weather in " + name;
    document.querySelector(".icon").src =
      "https://openweathermap.org/img/wn/" + icon + ".png";
    document.querySelector(".description").innerText = description;
    document.querySelector(".temp").innerText = temp + "°C";
    document.querySelector(".humidity").innerText =
      "湿度: " + humidity + "%";
    document.querySelector(".wind").innerText =
      "风速: " + speed + " km/h";
    document.querySelector(".weather").classList.remove("loading");
    document.body.style.backgroundImage =
      "url('https://source.unsplash.com/1600x900/?city " + name + "')";
    document.body.style.backgroundRepeat = "none";
    document.body.style.backgroundSize = "100";
    document.body.style.width = "100%";
    document.body.style.height = "100%";
    document.body.style.backgroundRepeat = "no-repeat";
    document.body.style.backgroundSize = "cover";

  },
  search: function () {
    this.fetchWeather(document.querySelector(".search-bar").value);
  },
};

document.querySelector(".search button").addEventListener("click", function () {
  weather.search();
});

document
  .querySelector(".search-bar")
  .addEventListener("keyup", function (event) {
    if (event.key == "Enter") {
      weather.search();
    }
  });

weather.fetchWeather("Shanghai");

第 6 步 - 免费托管您的网站!

现在,当您完成编码后,您可以在您的网站上托管您自己的天气应用程序,或者您甚至可以在 Github 上免费托管它!!!tv4少儿编程网-https://www.pxcodes.com

https://github.com/wanghao221/Weather.iotv4少儿编程网-https://www.pxcodes.com

托管是可选的,但我建议将其发布并与您的朋友和家人共享,并将其添加到您的项目列表中。 tv4少儿编程网-https://www.pxcodes.com

即将推出的功能tv4少儿编程网-https://www.pxcodes.com

这是我计划添加一些更酷的功能,例如tv4少儿编程网-https://www.pxcodes.com

每当您打开网站时进行位置检测,它将显示其天气特定位置的相关天气新闻使背景图像更准确地显示位置使其对大多数设备(iPad 和平板电脑)的响应速度更快tv4少儿编程网-https://www.pxcodes.com

项目中一些很酷的截图tv4少儿编程网-https://www.pxcodes.com

tv4少儿编程网-https://www.pxcodes.com

tv4少儿编程网-https://www.pxcodes.com

tv4少儿编程网-https://www.pxcodes.com

推荐学习:HTML/CSS视频教程、JS视频教程

以上就是教程篇:如何用JS和API制作天气Web应用程序(收藏)的详细内容,更多请关注少儿编程网其它相关文章!tv4少儿编程网-https://www.pxcodes.com

来源:php中文网tv4少儿编程网-https://www.pxcodes.com


相关文章:

支持一下 ( )

教程篇:如何用JS和API制作天气Web应用程序(收藏)

      匿名评论
    • 评论
    人参与,条评论
    教程篇:如何用JS和API制作天气Web应用程序(收藏)

微信公众号

免费视频教程

先知道