【功能实现】axios实现动态数据

1.安装axios

javascript 复制代码
npm i axios

2.axios调取数据

javascript 复制代码
	import { onMounted,ref } from "vue"
	const titleList=ref([])

    //获取数据库数据,将数据赋值给titleList
	 const getArticles = async () => {
	    const result = await axios.get('http://127.0.0.1:3000/getAccount')
	     titleList.value = result.data.data
	 	console.log(result.data.data);
	 }

    //调用getArticles方法
	onMounted(()=>{
		getArticles()
	})

3.页面使用数据

javascript 复制代码
 <template v-for="item in titleList" :key="item.id">
	        <routerLink :to="`/detail/${item._id}`" class="posts-item shadow-box">
	            <div class="posts-item__infos">
	                <div class="info__dates"><span class="yyc yy-date"></span><span>发布于 2024-12-06</span></div>
	                <h3 class="info__title">{{item.title}}</h3>
	                <div class="info__total">
	                    <div class="total__item"><span class="yyc yy-fire"></span><span>33阅读</span></div>
	                    <div class="total__item"><span class="yyc yy-comment"></span><span>22条评论</span></div>
	                    <div class="total__item"><span class="yyc yy-heart"></span><span>YYF</span></div>
	                </div>
	            </div>
	        </routerLink>
	    </template>

4.优化

1.新建utils文件夹,存放工具,新建request.ts文件

javascript 复制代码
import axios from 'axios'

const http= axios.create({
	 baseURL: '/api',// 通用请求地址前缀
	  timeout: 10000,//超时时间
})

// 添加请求拦截器
http.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么
    return config;
  }, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  });

// 添加响应拦截器
http.interceptors.response.use(function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response;
  }, function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
  });
export default http

2.新建api文件夹,在文件夹下新建index.ts文件

javascript 复制代码
import http from '../utils/request.js'

//请求全部文章数据
export const getArticles= () =>{
	//返回一个promise对象
	return http.get('http://127.0.0.1:3000/getArticle')
}

3.在首页直接调用使用

javascript 复制代码
	import { getArticles } from "../api";
	import { onMounted,ref } from "vue"
	const titleList=ref([])

	
	getArticles().then((data)=>{
		    titleList.value = data.data.data
			console.log(data.data.data);
	})
	

	onMounted(()=>{
		getArticles()
	})

4.好处

对于api的集中存放,增加代码规范化,后期更好维护

相关推荐
UXbot1 分钟前
AI原型设计工具评测:从创意到交互式Demo,5款产品全面解析
前端·ui·设计模式·ai·ai编程·原型模式
落魄江湖行2 分钟前
硅基同事埋的坑,我用2小时才填平:Nuxt 4 路由踩坑:可选参数 [[id]] 与 [id] 的区别
前端
一勺菠萝丶9 分钟前
管理后台使用手册在线预览与首次登录引导弹窗实现
java·前端·数据库
军军君019 分钟前
Three.js基础功能学习十四:智能黑板实现实例一
前端·javascript·css·typescript·前端框架·threejs·智能黑板
小村儿11 分钟前
连载05-Claude Skill 不是抄模板:真正管用的 Skill,都是从实战里提炼出来的
前端·后端·ai编程
xiaotao13117 分钟前
JS new 操作符完整执行过程
开发语言·前端·javascript·原型模式
robch24 分钟前
python3 -m http.server 8001直接启动web服务类似 nginx
前端·nginx·http
吴声子夜歌30 分钟前
ES6——数组的扩展详解
前端·javascript·es6
guhy fighting39 分钟前
new Map,Array.from,Object.entries的作用以及使用方法
开发语言·前端·javascript
大漠_w3cpluscom39 分钟前
CSS 技巧:CSS 单位使用指南
前端