SSMP整合案例(10) vue端调整项目环境 发送请求 基本界面编写

news2024/11/15 17:23:01

好 之前我们已经将后端服务整个写好了
然后 我们就继续回来写我们前端的项目 之前文章SSMP整合案例(1) 构建 Spring Boot Vue MySql项目环境中我们顺手搭建了前端的项目环境
我们打开它 在终端输入

npm i axios@0.21.0

引入 axios 它是一个专门用来发请求的第三方插件
在这里插入图片描述
一定要注意 @ 后的版本 这个还挺重要的

然后我们引入一下 Sass

在终端执行

npm install sass-loader node-sass@4.14.1 --save-dev

在这里插入图片描述
然后我们 Sass 就进来了

然后 我们在项目src目录下创建一个 文件夹 叫 utils
在这个文件夹下创建一个 request.js
request.js 参考代码如下

import axios from 'axios';

//在vue原型链中封装post请求方法
function createService () {
    // 创建一个 axios 实例
    const service = axios.create()
    // 请求拦截
    service.interceptors.request.use(
        //发送成功
        config => {
            //可在此配置请求头信息
            config.headers.Authorization = `Bearer`;
            return config
        },
        //发送失败
        error => {
            return error
        }
    )
    //响应拦截
    service.interceptors.response.use(
        //请求成功
        response => {
             //抛出返回值
             return response&&response.data?response.data:{state: 500,message: "系统异常"};
        },
        //请求失败
        (error) => {
            //返回错误信息
            return error;
        }
    )
    //抛出对象
    return service
}

function createRequestFunction (service) {
    return function (config) {
     const configDefault = {
     headers: {
        'Content-Type':'application/json'
     },
     timeout: 100000,
     baseURL: "",
     data: {}
   }
   return service(Object.assign(configDefault, config))
 }
}

const service = createService()
export const request = createRequestFunction(service);

我们做了一个 axios的二次封装
然后在src目录下创建一个 api文件夹 下面创建一个 bookApi.js
参考代码如下

import {request} from '@/utils/request'

export function get(params){
    return request({
        url:`/books`,
        method:'get',
        params:params,
    })
}

这里 我们定义了请求 http://localhost/books的函数 请求方式为get
但是 直接这样请求 肯定是跨域的

我们找到项目根目录下的 vue.config.js
在其中加上

devServer: {
 proxy: {
    "/books": {
        target: 'http://localhost/',
        ws: true,
        changeOrigin: true,
        pathRewrite: {
            ['^' + process.env.VUE_APP_BASE_API]: ''
        }
    },
  }
}

在这里插入图片描述
意思是 当匹配到books时 我们直接 代理到http://localhost/地址
就好比
/books 代理处理之后 就是 http://localhost/books

我们编写 src下的 App.vue组件代码如下

<template>
  <div class="app">
    
  </div>
</template>

<script>
import { getAll } from "@/api/bookApi.js"
export default {
  name: 'App',
  data() {
    return {
    
    }
  },
  mounted() {
    getAll({}).then(res => {
      console.log(res);
    })
  }
}
</script>

我们在mounted生命周期中调用了getAll 发送请求 并 接受返回结果
我们运行项目 可以看到 数据就正确的出现了
在这里插入图片描述

那么 我直接编写App组件代码如下

<template>
  <div class="app">
    <h1 class = "title">图书管理</h1>
    <el-form
      :inline="true"
      :model="formData"
      class="demo-form-inline"
      size="small"
    >
      <el-form-item>
        <el-input v-model="formData.type" placeholder="圈书类别"></el-input>
      </el-form-item>
      <el-form-item>
        <el-input v-model="formData.name" placeholder="图书名称"></el-input>
      </el-form-item>
      <el-form-item>
        <el-input v-model="formData.description" placeholder="图书描述"></el-input>
      </el-form-item>
      <el-form-item>
        <el-button @click="queryGet">查询</el-button>
        <el-button type="primary" @click="AddBook">新建</el-button>
      </el-form-item>
    </el-form>
    <el-table
      :data="bookList"
      style="width: 100%"
      height="calc(100vh - 200px)"
    >
      <el-table-column
        prop="name"
        label="图书名称"
      >
      </el-table-column>
      <el-table-column
        label="类别"
        width="180">
        <template slot-scope="scope">
            {{ typeIn[scope.row.type] }}
        </template>
      </el-table-column>
      <el-table-column
        prop="description"
        label="描述">
      </el-table-column>
    </el-table>
    <div class = "pages">
      <el-pagination
        background
        :page-size="page.pageSize"
        :page-count="page.pageCount"
        layout="prev, pager, next"
        :total="total">
      </el-pagination>
    </div>
  </div>
</template>

<script>
import { getAll } from "@/api/bookApi.js"
export default {
  name: 'App',
  data() {
    return {
      total: 0,
      page: {
        pageSize: 10,
        pageCount: 1
      },
      formData: {
          type: "",
          name: "",
          description: "",
      },
      bookList: [],
      typeIn: {
        0: "知识科普",
        1: "休闲图书",
        2: "官方记录",
        3: "典藏"
      }
    }
  },
  methods: {
    queryGet() {

    },
    AddBook() {
      
    },
    getAll() {
      getAll({}).then(res => {
        if(res.state == 200) {
          this.bookList = res.data;
        }else{
          this.$message.error(res.message);
        }
      })
    }
  },
  mounted() {
   this.getAll();
  }
}
</script>

<style>
*{
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
</style>

<style lang="scss" scoped>
.app{
  width: 100vw;
  height: 100vh;
  padding: 0 15px;
  .title{
    padding: 12px 0;
    border-bottom: 3px solid rgb(88,132,159);
    margin-bottom: 12px;
  }
  .pages{
    display: flex;
    justify-content:flex-end;
  }
}
</style>

我们的界面 差不多就出来一个雏形了
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/708044.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Nginx(4)nginx的反向代理

反向代理 正向代理反向代理的常用指令反向代理实战 Nginx的安全控制使用SSL对流量进行加密nginx添加SSL的支持Nginx的SSL相关指令生成证书 反向代理系统调优 正向代理代理的对象是客户端&#xff0c;反向代理代理的是服务端&#xff0c;这是两者之间最大的区别。Nginx即可以实现…

Python实现发送电子邮件功能

大家好&#xff0c;以编程方式发送电子邮件可以成为自动化通信过程的一种强大方式&#xff0c;本文将探讨如何使用Python发送电子邮件&#xff0c;介绍如何设置SMTP服务器、为Gmail生成应用程序密码&#xff0c;并提供使用smtplib库发送电子邮件的逐步指南。 在深入研究编码之…

单链表【数据结构】

1、顺序表存在的问题 顺序表存在一些问题&#xff1a; &#xff08;1&#xff09;中间、头部的插入删除&#xff0c;时间复杂度为O(N)&#xff08;2&#xff09;增容需要申请新空间&#xff0c;拷贝数据&#xff0c;释放旧空间。会有不小的消耗。&#xff08;3&#xff09;增容…

剑指 Offer 42: 连续子数组的最大和

这道题多了第二句&#xff0c;并且作为nums[i]&#xff0c;当前值一定是要取的&#xff0c;只是要不要加上前面那个而已。

uniapp 之 uniapp app 与uniapp H5的通信 webview,以及处理H5页面的手机物理返回问题

目录 app给H5传参&#xff1a;通过h5地址传参app给H5传参&#xff1a;通过方法evalJS传参H5给app传参&#xff1a;通过web-view 组件的message绑定的方法处理H5页面的手机物理返回问题 APP端&#xff1a; <web-view :webview-styles"webviewStyles" :src"sr…

python学习之【继承、封装、多态】

#来评选你心中的TOP1编程语言# 前言 距离上篇文章 python学习之【类和对象】已有三个星期之久&#xff0c;这篇文章介绍 面向对象的三大特征——封装&#xff0c;继承&#xff0c;多态。 对于编程初学者来说&#xff0c;学习python应该是比较好入手的&#xff0c;文末会给大家…

计算机视觉:多相机硬件同步拍摄

计算机视觉&#xff1a;多相机硬件同步拍摄 传感器同步硬件同步信号FSYNC信号STROBE信号 硬件接线硬件设备接线步骤&#xff1a; 软件驱动参考文献 传感器同步 目前主要有两种方法来同步不同传感器的信息&#xff08;帧、IMU数据包、ToF等&#xff09;&#xff1a; 硬件同步&…

2023-07-01:redis过期策略都有哪些?LRU 算法知道吗?

2023-07-01&#xff1a;redis过期策略都有哪些&#xff1f;LRU 算法知道吗&#xff1f; 答案2023-07-01&#xff1a; 缓存淘汰算法&#xff08;过期策略&#xff09; 当Redis的内存超出物理内存限制时&#xff0c;内存中的数据就会频繁地与磁盘进行交换&#xff0c;这个过程…

二叉树的练习

文章目录 单值二叉树检查两颗树是否相同对称二叉树二叉树的前序遍历二叉树的中序遍历二叉树的后序遍历另一颗树的子树通过前序遍历的数组构建二叉树判断二叉树是否是完全二叉树层序遍历k层节点数二叉树的销毁二叉树的整体 单值二叉树 单值二叉树&#xff0c;可以使用等式的传递…

Java基础---有了基本类型为什么还需要包装类

目录 缘由 基本类型和包装类型的区别 如何理解自动拆装箱 哪些地方会自动拆装箱 自动拆装箱与缓存 缘由 Java中有8种基本数据类型&#xff0c;这些基本类型又都有对应的包装类 因为Java是一种面向对象语言&#xff0c;很多地方都需要使用对象而不是基本数据类型比如&…

Domino Admin管理客户机中为每个管理域设置不同的图标

大家好&#xff0c;才是真的好。 一直在讲Domino管理中的单个网络 域&#xff0c;很少讲到多个Domino网络域的管理。其实&#xff0c;很多企业会有多个Domino网络域。因为以前多个部门或组织、企业等合并&#xff0c;或者隔离国内和国外的目录隔开等等&#xff0c;都会产生多个…

从0-1手写一个RPC框架

前言 什么是RPC RPC&#xff08;Remote Procedure Call&#xff09;远程过程调用&#xff0c;简言之就是像调用本地方法一样调用远程服务。目前外界使用较多的有gRPC、Dubbo、Spring Cloud等。相信大家对RPC的概念都已经很熟悉了&#xff0c;这里不做过多介绍。 为啥要自己写…

nvm 和 nrm安装使用

前端工具推荐&#xff1a;nvm&#xff08;Node 版本管理工具&#xff09; 和 nrm&#xff08;管理npm源&#xff09;&#xff1a; 一、nvm 1.1 nvm 是什么 1.2 安装 nvm 1.3 使用 nvm 二、nrm 2.1 nrm 是什么 2.2 安装 nrm 2.3 使用 nrm 一、nvm 如果直接将 node 安装到…

20230701:成电的“七年之痒”,毕业啦

毕业那些事儿 毕业随笔写在最后 毕业随笔 伴随着走完最后一道流程&#xff0c;成电7年&#xff0c;总算是毕业了。经济下行&#xff0c;行业寒冬&#xff0c;全被90后赶上了&#xff0c;庆幸学校的金字招牌让自己斩获了不少OFFER。荒废了半年的跑步和博客计划&#xff0c;接下…

【测试开发】概念基础

目录 一. 需求 1. 用户需求 2. 软件需求 3. 从测试人员的角度看需求 二. 测试用例 三. BUG 四. 开发模型 1. 软件的生命周期 2. 开发模型 2.1 瀑布模型 2.2 螺旋模型 2.3 增量&#xff0c;迭代模型 2.4 敏捷模型 SCRUM 五. 测试模型 1. V模型 2. W模型 (双V模…

开源免费的多数据库工具Chat2DB

Chat2DB使用 当前使用的版本为1.0.11。 一.Chat2DB介绍 Chat2DB 是一款开源免费的多数据库客户端工具。 能够将自然语言转换为SQL&#xff0c;也可以将SQL转换为自然语言。 支持windows、mac本地安装&#xff0c;也支持服务器端部署&#xff0c;web网页访问。 支持多种数据库…

Hexo基本建站

目录 一、前言 二、Hexo安装、新建、启动 三、架构说明 四、写博客 五、打包 六、发布到GitHub 1.新建仓库 2.安装插件 3.修改配置文件&#xff1a;_config.yml 4.部署github 5.查看仓库 6.访问网站 一、前言 安装 Git安装 Node.js 二、Hexo安装、新建、启动 # 安装 h…

智慧园区平台建设解决方案

智慧园区是指利用现代互联网物联网技术&#xff0c;对园区内的设施、设备和人员进行高效管理和智能化运营的一种模式。越来越多的城市开始致力于发展智慧园区&#xff0c;实现园区内的资源共享和高效利用。为了让智慧园区达到最佳的效果&#xff0c;我们需要从平台建设方面入手…

Prettier - Code formatter配置(vscode)

1.安装Prettier 2.设置-->搜索format on save 并打勾 3.搜索default format 并选择Prettier - Code formatter 4.点击右上角打开setting.json 5.看最后一行是否存在如下配置,有就说明配置成功,没有重新前面步骤重新设置一下 6.根目录是否存在.prettierrc.json,没有创建一下 …

vue3原理和源码分析 - watch 源代码

https://github.com/vuejs/vue-next/blob/master/packages/runtime-core/src/apiWatch.ts 目录 Watch /packages/runtime-core/src/apiWatch.ts watch.dot https://github.com/vuejs/vue-next/blob/master/packages/runtime-core/src/apiWatch.ts Watch /packages/runtime…