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

在本次实例中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;这里我只列举一个属性的显示

结果:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 前端中从数据库中获取数据显示前端,一般需要通过后端接口来实现数据的获取和传输。以下是一般的步骤: 1. 创建后端接口:在后端(比如使用 Node.js、PHP、Python 等)创建一个接口用于从数据库中获取数据。该接口可以使用数据库查询语言(如 SQL)来查询数据,并将查询结果以 JSON 格式返回给前端。 2. 在前端使用 Axios(或其他 HTTP 请求库)发起请求:在前端代码中,使用 Axios(或其他合适的库)发送 HTTP 请求到后端接口,获取数据。 3. 在前端组件中处理获取的数据:在 Vue 组件中,可以使用生命周期钩子函数(如 `mounted`)或者方法来处理从后端获取的数据。将数据存储在组件的 data 中,并在模板中进行遍历和展示。 下面是一个简单的示例代码: ```html <template> <div> <ul> <li v-for="item in items" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> import axios from 'axios'; export default { data() { return { items: [] }; }, mounted() { // 发起请求获取数据 axios.get('/api/items') .then(response => { this.items = response.data; }) .catch(error => { console.error(error); }); } }; </script> ``` 在上述示例中,通过 `mounted` 钩子函数在组件挂载后发起请求,并将获取到的数据保存在 `items` 数组中,然后通过 `v-for` 指令在模板中遍历并展示数据。 需要注意的是,以上只是一个简单的示例,实际情况可能会更复杂,涉及到数据处理和错误处理等。具体实现方式还需要根据后端接口和数据库的具体情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值