Ajax-03.Axios-案例

基于Vue以及Axios完成数据动态加载展示

1.数据准备的url:https://yapi.pro/mock/401965/user/getById

2.在页面加载完成后,自动发送异步请求,加载数据,渲染展示页面(性别:1代表男,2代表女)

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Ajax-Axios-案例</title>
    <script src="js/axios.js"></script>
    <script src="js/vue.js"></script>
    <style>
        table {
            text-align: center;
            margin: 0 auto;
            border: 1px solid black;
        }
        th,td {
            border: 1px solid black;
        }
    </style>
</head>
<!-- 
    基于Vue以及Axios完成数据动态加载展示
    1.数据准备的url:https://yapi.pro/mock/401965/user/getById
    2.在页面加载完成后,自动发送异步请求,加载数据,渲染展示页面(性别:1代表男,2代表女)
-->
<body>
    <div id="app">
        <table cellspacing="0" width="60%">
            <tr>
                <th>编号</th>
                <th>姓名</th>
                <th>图像</th>
                <th>性别</th>
                <th>职位</th>
                <th>入职日期</th>
                <th>最后操作时间</th>
            </tr>

            <tr v-for="(emp,index) in emps">  <!-- 遍历展示数组emps中的数据 -->
                <td >{{index + 1}}</td>
                <td>{{emp.name}}</td>
                <td>
                    <img  v-bind:src="emp.image" width="70px" height="50px">
                </td>
                <td>
                    <span v-if="emp.gender == 1">男</span>
                    <span v-if="emp.gender == 2">女</span>
                </td>
                <td>{{emp.job}}</td>
                <td>{{emp.entrydate}}</td>
                <td>{{emp.updatedate}}</td>
            </tr>
        </table>
    </div>
</body>
<script>
    new Vue({
        el:"#app",
        data:{
            emps:[] // 赋值给vue中的数据模型emps数组
        },
        mounted () {  // mounted:vue生命周期中的挂载完成状态,当挂载完成后,自动调用axios的get方法用来向服务器请求数据
            // 发送异步请求,加载数据
            axios.get("https://yapi.pro/mock/401965/user/getById").then(result => {  // 将请求到的数据交给一个result对象
                /*  
                调用result中的data属性拿到数据,然后我们只需要拿到服务器中的data这个属性名对应下的属性值即可,因此再次.data 
                然后把他交给this.emps,this代表的就是当前对象,emps就是vue对象下的一个数据模型(是一个数组)
                */
                this.emps = result.data.data;   
            });
        }
    })
</script>
</html>
相关推荐
林太白9 分钟前
八大数据结构
前端·后端·算法
一 乐10 分钟前
流浪动物救助|流浪猫狗救助|基于Springboot+vue的流浪猫狗救助平台设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设
火星数据-Tina10 分钟前
Python + WebSocket 实现实时体育比分系统(含数据库设计与前端演示)
开发语言·前端
国思RDIF框架18 分钟前
国思RDIF低代码快速开发框架 v6.2.2版本发布
前端·vue.js·后端
oil欧哟34 分钟前
Agent 设计与上下文工程- 02 Workflow 设计模式(上)
前端·网络·人工智能
StarkCoder34 分钟前
GetX 状态管理优化:从 GetBuilder 到 Obx 的性能提升实践
前端
小高00735 分钟前
深入理解 package.json:前端项目的 "身份证"
前端·javascript·vue.js
StarkCoder37 分钟前
Flutter ListView 数据变动导致的卡顿与跳动问题:Key 的妙用
前端
lichenyang45339 分钟前
Next.js 学习笔记:从约定式路由到 Tailwind、Image、Font 优雅整合。
前端·javascript·全栈
杂鱼豆腐人39 分钟前
【自用】CSS查漏补缺
前端·css