锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. 前端
  4. 用Vue和Axios将数据库数据显示在前端页面

用Vue和Axios将数据库数据显示在前端页面

0
  • 前端
  • 发布于 2024-09-21
  • 14 次阅读
黄健
黄健

在本次实例中Vue只用在了前端部分,Axios用于向后端请求数据,我们这里要用到Ajax技术来访问后端数据。

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <!-- 引入vue开发库 -->
     <script src="vue.js"></script>
<!--    引入axios库用于发送HTTP请求-->
    <script src="axios.js"></script>
</head>
<body>
<!--Vue实例挂载点-->
    <div id="app">
<!--        定义展示页面-->
       <table> 
        <tr>
            <th>名字</th>
        </tr>
<!--用Vue的指令遍历msg数组中的每一项,并为每一行生成一个表格-->
        <tr v-for="(value,index) in msg">
<!--双大括号是 Vue.js 的插值语法,用于将遍历出来的属性在HTML模板中插入数据-->
<td>{
  {msg[index].name}}</td>
        </tr>
       </table>
    </div>
<!--引入包含Vue实例定义的JS文件-->
    <script src="vuestu.js"></script>
</body>
</html>

JS;

new Vue({
    // 挂载DOM元素
    el: "#app",
    //用来返回数据
    data() {
        return {
            //初始化msg
            msg:null,
            //包含属性的对象
            adddata: {
                name: ""
            },
         }
    },
// created 是 Vue 的生命周期钩子之一,在 Vue 实例被创建之后立即执行。
// 在这个阶段,DOM 尚未被渲染,但是数据观测和事件配置已经完成。
    created(){
        axios
        // 使用 Axios 库发送 GET请求到后端数据
            .get('/ajax_war_exploded/A')
            //response 参数包含了服务器返回的数据
            //将服务器返回的数据赋值给 Vue 实例的 msg 属性
            .then(response=>(this.msg=response.data))

            .catch(function (error){
            console.log(error)
        }
        )
    },
}
)

后端:

import com.alibaba.fastjson.JSON;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.List;
@WebServlet("/A")
public class axio extends HttpServlet {
    private InputStream in;
    private SqlSessionFactory factory;
    private SqlSession session;
    UserDao userDao;
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doPost(req, resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
       //动态生成表单
        resp.setContentType("application/json;charset=utf-8");
        req.setCharacterEncoding("utf-8");
        in = Resources.getResourceAsStream("mybatis-config.xml");
        factory = new SqlSessionFactoryBuilder().build(in);
        session = factory.openSession();
        userDao = session.getMapper(UserDao.class);
        List<stu> findall = userDao.findall();
        String stu = JSON.toJSONString(findall);
//传回前端json格式的字符串 key--value
//这一行代码设置了 HTTP 响应的内容类型为 application/json,同时指定了字符集为 utf-8。
        PrintWriter writer = resp.getWriter();
        writer.write(stu);
        //释放缓存和对象
        writer.flush();
        writer.close();
    }
}

最后有JavaBean;这里我只列举一个属性的显示

结果:


原文链接: https://blog.csdn.net/daibadetianshi/article/details/140935780

标签: #VUE 61 #前端 145
相关文章

vue2路由和vue3路由区别及原理 2024-10-08 11:24

一、Vue2 与 Vue3 路由的区别 1. 创建路由实例方式的不同 Vue 2 中,通过 Vue.use() 注册路由插件,并通过 new VueRouter() 来创建路由实例。 import Vue from 'vue';import VueRouter from 'vue-router';i

vue项目 部署到nginx 上刷新页面显示404 2024-09-30 17:34

在Vue项目部署到Nginx服务器上时,遇到刷新页面显示404的问题,通常是因为Nginx无法正确地处理Vue路由(尤其是单页面应用(SPA)中的前端路由)。Vue应用的路由是前端路由,依赖于JavaScript来动态解析URL,当直接访问除根路径外的URL时,Nginx默认会尝试在服务器上找到对应

三小时快速上手TypeScript,TS速通教程(上篇、中篇、下篇、附加篇) 2024-09-29 11:21

TypeScript速通 Typescript简介 为什么需要TypeScript * JavaScript今非昔比 JavaScript中的困扰 1. 不清不楚的数据类型 2. 有漏洞的逻辑 3. 访问不存在的属性 4. 低级的拼写错误 TypeScrip

js中的事件冒泡是什么? 2024-09-29 11:21

事件冒泡(Event Bubbling)是JavaScript中一种事件传播机制。当一个事件(如点击、键盘输入等)发生在某个元素上时,浏览器会首先触发该元素上的特定事件处理函数(如果存在的话)。然后,该事件会从当前元素向其父元素逐级传播,直到达到元素或整个文档树。这种从触发元素开始,逐级向上传播的事

Vue.js 的 Mixins 2024-09-26 17:57

Vue.js 的 Mixins 是一种非常强大且灵活的功能,它允许你封装可复用的 Vue 组件选项。Mixins 实际上是一种分发 Vue 组件可复用功能的非常灵活的方式。一个 mixin 对象可以包含任意组件选项。当组件使用 mixin 时,所有 mixin 选项将被"混入"该组件本身的选项。 M

前端框架对比和选择 2024-09-26 17:57

在前端开发的广阔领域中,框架的选择对于项目的成功至关重要。不同的框架各具特色,适用于不同的开发需求和项目规模。本文将对当前最流行的三大前端框架——React、Vue和Angular进行详细对比,并探讨如何根据项目需求选择合适的框架。 一、React 1. 简介 React是由Facebook开发和维

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.