Vue3 (五)集成HTTP库axios详情

2022-04-15 0 323
目录
  • 一、安装 axios
  • 二、axios的使用
    • 1、在主页中引用 axios
    • 2、重新启动服务
    • 3、何为跨域?
    • 4、解决跨域问题
    • 5、重新启动后端服务,再次访问
  • 三、结论

    一、安装 axios

    npm install axios@0.21.0 --save
    
    

    二、axios的使用

    1、在主页中引用 axios

    Vue3新增了setup初始化方法,所以我们在这里开始使用并测试,示例代码如下:

    <template>
      <a-layout>
        <a-layout-sider width="200" style="background: #fff">
          <a-menu
              mode="inline"
              v-model:selectedKeys="selectedKeys2"
              v-model:openKeys="openKeys"
              :style="{ height: '100%', borderRight: 0 }"
          >
            <a-sub-menu key="sub1">
              <template #title>
                    <span>
                      <user-outlined />
                      subnav 1
                    </span>
              </template>
              <a-menu-item key="1">option1</a-menu-item>
              <a-menu-item key="2">option2</a-menu-item>
              <a-menu-item key="3">option3</a-menu-item>
              <a-menu-item key="4">option4</a-menu-item>
            </a-sub-menu>
            <a-sub-menu key="sub2">
              <template #title>
                    <span>
                      <laptop-outlined />
                      subnav 2
                    </span>
              </template>
              <a-menu-item key="5">option5</a-menu-item>
              <a-menu-item key="6">option6</a-menu-item>
              <a-menu-item key="7">option7</a-menu-item>
              <a-menu-item key="8">option8</a-menu-item>
            </a-sub-menu>
            <a-sub-menu key="sub3">
              <template #title>
                    <span>
                      <notification-outlined />
                      subnav 3
                    </span>
              </template>
              <a-menu-item key="9">option9</a-menu-item>
              <a-menu-item key="10">option10</a-menu-item>
              <a-menu-item key="11">option11</a-menu-item>
              <a-menu-item key="12">option12</a-menu-item>
            </a-sub-menu>
          </a-menu>
        </a-layout-sider>
        <a-layout-content
            :style="{ background: '#fff', padding: '24px', margin: 0, minHeight: '280px' }"
        >
          Content
        </a-layout-content>
      </a-layout>
    </template>
    
    <script lang="ts">
    import { defineComponent } from 'vue';
    import axios from 'axios';
    
    export default defineComponent({
      name: 'Home',
      setup(){
        console.log('set up');
        axios.get("http://localhost:8888/ebook/list?name=spring").then(response =>{
          console.log(response);
        })
      }
    });
    </script>
    

    2、重新启动服务

    启动服务后,打开主页,并没有任何异常,如下图:

    Vue3 (五)集成HTTP库axios详情

    but ,事情并没有我我们想象的那么好,你敢打开 F12 看下控制台吗?

    有啥不敢的,那我就打开,如下图:

    Vue3 (五)集成HTTP库axios详情

    忽略警告部分,红圈部分就是报错了。

    报错不要慌,这不是很正常个事吗,有问题解决就好了,很明显就是个跨越问题,简单来说就是,虽然是同一个 IP ,但是端口不同,导致没法访问。

    3、何为跨域?

    可以这样理解,来自一个IP端口的页面( vue 项目),要访问另一个IP端口的资源( springboot 请求接口),会产生跨域访问。

    4、解决跨域问题

    增加 CorsConfig 配置类,解决跨域问题,示例代码如下:

    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.cors.CorsConfiguration;
    import org.springframework.web.servlet.config.annotation.CorsRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
    
    @Configuration
    public class CorsConfig implements WebMvcConfigurer {
    
        @Override
        public void addCorsMappings(CorsRegistry registry) {
            registry.addMapping("/**")
                    .allowedOriginPatterns("*")
                    .allowedHeaders(CorsConfiguration.ALL)
                    .allowedMethods(CorsConfiguration.ALL)
                    .allowCredentials(true)
                    .maxAge(3600); // 1小时内不需要再预检(发OPTIONS请求)
        }
    
    }
    
    

    5、重新启动后端服务,再次访问

    下面就是见证奇迹的时候了, F12 看到真相,忽略警告,可以看到,打印出的 response 内容,如下图所示:

    Vue3 (五)集成HTTP库axios详情

    三、结论

    这块其实我们也可以使用 jQuery 来做,都是一样的,具体喜欢哪个,还需要看自己习惯了,到此,集成 HTTP axios 介绍完,感兴趣的同学请自行尝试。

    到此这篇关于Vue3 集成HTTPaxios详情的文章就介绍到这了,更多相关Vue3 集成HTTP库axios内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript Vue3 (五)集成HTTP库axios详情 https://www.niceym.com/26208.html