Vue+elementUI+springboot+mybatis demo教程(三)

本文介绍Axios的使用方法及跨域处理技巧,并演示如何利用Mock.js模拟数据,帮助前端开发者独立完成开发。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上篇文章结尾介绍了今天这篇文章主要内容包括axios使用、跨域处理,以及mock.js的使用

axios使用

Axios是基于 Promise 的 HTTP 请求客户端,可同时在浏览器和 node.js 中使用,有人可能会问axios 和ajax有什么关联呢?实际上axios是通过promise实现对ajax技术的一种封装,就像jQuery实现ajax封装一样。
简单用法如下
Get 请求

getUserList(){
     var _this=this;
     this.$http.get('/TbItem/list'
       ,{
          params:{
            pageNo:_this.currentPage,
            pageSize:_this.pageSize
          }
        }
     ).then(function(responese){
       _this.tableData=responese.data.itemList;
       window.console.log(_this.tableData)
       _this.total=responese.data.total;
     })
  }

Post请求

  //删除
  handleDelete(index, row) {
    var _this = this;
    _this.$confirm('是否要删除此商品', '提示',{
      confirmButtonText: '确定',
      cancelButtonText: '取消',
      type: 'warning'
    }).then(()=>{
        //删除
         _this.$http.post("/TbItem/delete",{
              id:row.id,
         }).then((responese)=>{
           window.console.log(responese)
           if(responese.data.success=="success") {
             //弹出消息提示框并跳转到列表页
             _this.$message({
               title: '',
               message: '删除成功',
               type: 'success',
               center: true

             });
             this.getUserList();
           }

         });
    })

  }

跨域处理

本地开发环境:
通过npm run dev 的方式来启动项目,在项目的Config 目录下index.js 中有个procyTable:{}参数,配置该参数可达到跨域目的
配置方式如下图所示
这里写图片描述

生产环境中 npm run build
通过 npm run build 打包 之后对应项目下多出了dist 目录,将该文件下的内容拷贝到Tomcat目录下webapp 的某个目录下访问,我配置的是demo目录,所启动Tomcat服务器后
这里写图片描述
这里写图片描述

通过上面可以看到css 等文件访问不到了,修改步骤如下:在build 文件夹下面修改utils.js,添加红框框住的一句

这里写图片描述

在config目录下修改index.js ,修改成红框中的内容

这里写图片描述

这里写图片描述

上述操作主要为了解决css,js 之类文件的路径问题,修改之后重新打包,部署已经可以正常访问了,现在的问题就是跨域的问题了,跨域问题需要通过nginx 来设置访问,此时不用通过Tomcat来访问项目了。请先安装nginx ,再进行如下配置

这里写图片描述

配置后重启nginx

这里写图片描述

已经可以跨域获取数据了

这里写图片描述

mock.js的使用

在后端接口还未完成时,前端开发人员工作也不能停下来,这时可以通过mock.js来满足需求。Mock 用于生成随机数据,拦截Ajax请求, 用于模拟后台接口返回数据,让前端开发人员可以独立于后端进行开发。先安装mock.js
这里写图片描述

在项目中新建一个js文件
这里写图片描述

Main.js 中引入已经写好的js文件

这里写图片描述

在项目中使用
这里写图片描述

效果如下:随机生成树形控件数据

这里写图片描述

有关于mock.js的更多用法可以查看官方文档 http://mockjs.com/

好的,我可以为你解答。以下是一个简单的实现步骤: 1. 创建数据库表 首先,你需要在 MySQL 数据库中创建一个表来存储搜索数据。例如,可以创建一个名为 `product` 的表,包含 `id`、`name` 和 `description` 个字段。 ```sql CREATE TABLE product ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255), description TEXT ); ``` 2. 创建后端服务 使用 Spring Boot 和 MyBatis 框架来创建一个后端服务,可以接收搜索请求并从数据库中获取数据。具体实现步骤如下: - 添加相关依赖 在 `pom.xml` 文件中添加 MyBatis 和 MySQL 相关依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.6</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.25</version> </dependency> ``` - 配置数据库连接 在 `application.properties` 中添加数据库连接配置: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8&useSSL=false spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` - 创建数据模型 创建一个名为 `Product` 的 Java 类,用于映射数据库表中的数据: ```java public class Product { private Integer id; private String name; private String description; // 省略 getter 和 setter 方法 } ``` - 创建 MyBatis 映射文件 创建一个名为 `ProductMapper.xml` 的 MyBatis 映射文件,用于定义 SQL 语句和数据模型的映射关系: ```xml <mapper namespace="com.example.demo.mapper.ProductMapper"> <select id="search" resultType="com.example.demo.model.Product"> SELECT * FROM product WHERE name LIKE CONCAT('%', #{keyword}, '%') </select> </mapper> ``` - 创建数据访问层 创建一个名为 `ProductMapper` 的 Java 接口,用于定义数据访问方法: ```java @Mapper public interface ProductMapper { List<Product> search(String keyword); } ``` - 创建控制器 创建一个名为 `ProductController` 的 Spring MVC 控制器,用于接收搜索请求和返回搜索结果: ```java @RestController public class ProductController { @Autowired private ProductMapper productMapper; @GetMapping("/search") public List<Product> search(@RequestParam("keyword") String keyword) { return productMapper.search(keyword); } } ``` 至此,后端服务的实现就完成了。 3. 创建前端界面 在前端界面中,可以使用 VueElementUI 的 `el-input` 和 `el-table` 组件来实现搜索和显示数据的功能。例如,可以实现如下代码: ```html <template> <div> <el-input v-model="keyword" placeholder="请输入搜索关键字" @keyup.enter.native="search" /> <el-table :data="data"> <el-table-column prop="name" label="名称" /> <el-table-column prop="description" label="描述" /> </el-table> </div> </template> <script> export default { data() { return { keyword: '', data: [] }; }, methods: { async search() { const { data } = await this.$http.get('/search', { params: { keyword: this.keyword } }); this.data = data; } } }; </script> ``` 这段代码会创建一个包含搜索输入框和显示搜索结果的界面,当用户输入关键字并按下回车键时,会向后端发送搜索请求,并将结果显示在表格中。 以上就是一个简单的使用 Spring Boot、MyBatisVueElementUI 来创建搜索功能的实现步骤。当然,具体实现方式还需要根据你的具体需求来进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值