首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第 14 章 基于Vue的网络框架vue-axios的应用
14.1 使用vue-axios请求天气数据
14.1.1 使用互联网上免费的数据服务
14.1.2 使用vue-axios进行数据请求
14.2 vue-axios实用功能介绍
14.2.1 通过配置的方式进行数据请求
14.2.2 请求的配置与响应数据结构
14.2.3 拦截器的使用
14.3 实战:天气预报应用
14.3.1 搭建页面框架
14.3.2 实现天气预报应用核心逻辑
第 15 章 Vue路由管理
15.1 Vue Router的安装与简单使用
15.1.1 Vue Router的安装
15.1.2 一个简单的Vue Router的使用示例
15.2 带参数的动态路由
15.2.1 路由参数匹配
15.2.2 路由匹配的语法规则
15.2.3 路由的嵌套
15.3 页面导航
15.3.1 使用路由方法
15.3.2 导航历史控制
15.4 关于路由的命名
15.4.1 使用名称进行路由切换
15.4.2 路由视图命名
15.4.3 使用别名
15.4.4 路由重定向
15.5 关于路由传参
15.6 路由导航守卫
15.6.1 定义全局的导航守卫
15.6.2 为特定的路由注册导航守卫
15.7 动态路由
第 16 章 Vue状态管理
16.1 认识Vuex框架
16.1.1 关于状态管理
16.1.2 安装与体验Vuex
16.2 Vuex中的一些核心概念
16.2.1 Vuex中的状态state
16.2.2 Vuex中的Getter方法
16.2.3 Vuex中的Mutation
16.2.4 Vuex中的Action
16.2.5 Vuex中的Module 333
当前位置:
首页>>
技术小册>>
TypeScript和Vue从入门到精通(五)
小册名称:TypeScript和Vue从入门到精通(五)
### 14.1 使用vue-axios请求天气数据 在开发Web应用程序时,与后端服务或第三方API交互是一项常见且重要的任务。Vue.js作为前端框架,结合axios库,可以高效地处理HTTP请求,实现数据的获取、更新等功能。本章节将详细介绍如何在Vue项目中集成并使用vue-axios(实际上是axios库,因为Vue官方并没有直接提供名为vue-axios的库,但axios因其易用性和与Vue的良好集成而广受欢迎)来请求天气数据。 #### 14.1.1 理解axios与Vue的集成 axios是一个基于Promise的HTTP客户端,适用于浏览器和node.js。它简化了HTTP请求的发送和处理,支持请求和响应的拦截、转换请求数据和响应数据等高级功能。在Vue项目中使用axios,可以让我们轻松地从服务器获取数据并更新到Vue组件的响应式数据中。 虽然Vue官方没有直接提供axios的封装库,但社区中有很多基于axios的Vue插件,如vue-axios-next(针对Vue 3)或vue-axios(针对Vue 2,但需注意这是一个第三方库,并非Vue官方出品)。然而,为了保持本教程的通用性和简洁性,我们将直接通过npm安装axios,并在Vue项目中手动配置和使用它。 #### 14.1.2 安装axios 首先,你需要在你的Vue项目中安装axios。打开终端或命令提示符,切换到你的Vue项目目录,然后运行以下npm命令: ```bash npm install axios ``` 这将把axios添加到你的项目依赖中。 #### 14.1.3 配置axios(可选) 虽然直接导入axios并使用它就可以发起HTTP请求,但为了更好地管理API请求,你可以创建一个axios实例并配置一些全局设置,如基础URL、请求头、超时时间等。这有助于减少在每个请求中重复相同配置的需要。 ```javascript // src/plugins/axios.js import axios from 'axios'; const service = axios.create({ baseURL: 'https://api.openweathermap.org/data/2.5/', // 示例:OpenWeatherMap API的基础URL timeout: 5000, // 请求超时时间 headers: { 'Content-Type': 'application/json' // 根据需要添加其他全局请求头 } }); // 可以在这里添加请求或响应拦截器 service.interceptors.request.use( config => { // 在发送请求之前做些什么 // 例如,为每个请求添加token // if (store.getters.token) { // config.headers['Authorization'] = `Bearer ${token}`; // } return config; }, error => { // 对请求错误做些什么 console.error('请求配置出错', error); return Promise.reject(error); } ); service.interceptors.response.use( response => { // 对响应数据做点什么 // 例如,根据状态码判断请求是否成功 if (response.status === 200) { return response.data; } else { console.error('响应错误', response); return Promise.reject(new Error('请求失败')); } }, error => { // 对响应错误做点什么 console.error('响应错误', error); return Promise.reject(error); } ); export default service; ``` 然后,在你的Vue项目中导入并使用这个配置好的axios实例。 #### 14.1.4 使用axios请求天气数据 现在,我们将使用axios来请求天气数据。以OpenWeatherMap API为例,该API提供了丰富的天气数据,包括当前天气、未来几天的天气预报等。首先,你需要在OpenWeatherMap注册账号并获取一个API密钥(API key)。 接下来,在你的Vue组件中,你可以这样使用axios来请求天气数据: ```vue <template> <div> <h1>天气信息</h1> <div v-if="weatherData"> <p>城市: {{ weatherData.name }}</p> <p>天气状况: {{ weatherData.weather[0].description }}</p> <p>温度: {{ weatherData.main.temp }}°C</p> <!-- 其他需要展示的数据 --> </div> <div v-else> 加载中... </div> </div> </template> <script> // 导入axios实例 import axios from '@/plugins/axios'; // 路径根据你的项目结构而定 export default { data() { return { weatherData: null, }; }, created() { this.fetchWeatherData('Beijing', 'CN'); // 假设我们请求北京的天气 }, methods: { async fetchWeatherData(city, countryCode) { try { const response = await axios.get( `weather?q=${city},${countryCode}&appid=YOUR_API_KEY_HERE&units=metric&lang=zh_cn` ); this.weatherData = response; } catch (error) { console.error('请求天气数据失败', error); // 处理错误,例如显示错误消息 } } } }; </script> ``` **注意**:在上面的代码中,请将`YOUR_API_KEY_HERE`替换为你的OpenWeatherMap API密钥。同时,确保你的API请求URL正确无误,并根据需要调整`q`、`appid`、`units`和`lang`等参数。 #### 14.1.5 错误处理与加载状态 在上面的示例中,我们已经简单处理了错误情况(在控制台打印错误信息)。但在实际应用中,你可能需要向用户展示更友好的错误消息,或者在某些情况下(如网络请求中)显示加载状态。 你可以通过添加一个加载状态到Vue组件的`data`函数中来实现这一点: ```javascript data() { return { weatherData: null, isLoading: false, errorMessage: '', }; }, methods: { async fetchWeatherData(city, countryCode) { this.isLoading = true; this.errorMessage = ''; // 清除之前的错误消息 try { const response = await axios.get(...); this.weatherData = response; } catch (error) { this.errorMessage = '加载天气数据时出错'; // 更新错误消息 } finally { this.isLoading = false; // 请求完成,无论成功还是失败,都更新加载状态 } } } ``` 然后在模板中根据`isLoading`和`errorMessage`的值来显示相应的UI元素。 #### 14.1.6 小结 通过本章节,我们学习了如何在Vue项目中使用axios来请求天气数据。我们首先安装了axios,并可选地配置了axios实例。然后,在Vue组件中,我们通过axios发送HTTP GET请求到天气API,并在组件的模板中展示了返回的数据。最后,我们还讨论了错误处理和加载状态的显示方法。这些技能对于开发需要与后端或第三方API交互的Vue应用程序至关重要。
上一篇:
第 14 章 基于Vue的网络框架vue-axios的应用
下一篇:
14.1.1 使用互联网上免费的数据服务
该分类下的相关小册推荐:
Vue源码完全解析
VUE组件基础与实战
vuejs组件实例与底层原理精讲
TypeScript和Vue从入门到精通(一)
Vue.js从入门到精通(四)
Vue.js从入门到精通(二)
TypeScript和Vue从入门到精通(三)
Vue.js从入门到精通(一)
Vue.js从入门到精通(三)
Vue原理与源码解析
Vue3技术解密
TypeScript和Vue从入门到精通(二)