通过vue如何设置header

 更新时间:2023年02月23日 10:33:25   作者:三知之灵  
这篇文章主要介绍了通过vue如何设置header,每个项目都有头部但是内容不一样;这种情况我们可以考虑在app.vue中创建公共头部,那么怎么配置公共头部header,下面小编通过实例代码详细讲解,需要的朋友可以参考下

vue设置header

使用vue-resource与vue-cookie实现页面登录,数据存储与后台的数据交互

后端交互对vue中contentType,和ajax的contentType区别对待

this.$http
        .post(netUrl, change, {
          headers: {
            Authorization: "Bearer " + this.$cookies.get("token")
          }
        })
        .then(
          response => {
            console.log(response.data);
            if (response.data != null) {
            }
          },
          response => {
            console.log("error");
          }
        );

当服务器端需要设置contentType:“application/json”:

如果采用的是传统的$.ajax方式进行交互时设置contentType:"application/json;charset=UTF-8"也会导致服务器访问不成功必须严格设置为contentType:“application/json”;

在这里插入图片描述

当使用vue中的vue-resource方式交互时,即使不设置contentType:"application/json"也可成功交互;

vue方式交互

为什么ajax要求那么严格,原因还不是很清楚;
但是我们可以通过以上方式:每个http请求中加入以下代码,进行设置请求头

 headers: {
    Authorization: "Bearer " + this.$cookies.get("token")
  }

全局设置请求头

虽然上述方式可以成功的设置请求头,但是每个请求都设置显得繁琐,而从网上查找解决方案始终没有成功解决
解决问题的主要思路:

1.使得请求头中存在token

在这里插入图片描述

网上提供方式:

Vue.http.interceptors.push((request, next) => {
      // ...
      // 请求发送前的处理逻辑
     request.beforeSend = function() {
             request.headers['token'] = “token”;
     }
  next((response) => {
      // ...
      // 请求发送后的处理逻辑
      // ...
      // 根据请求的状态,response参数会返回给successCallback或errorCallback
      return response
  })

测试后发现用以上拦截器的方式不可行,查到网上有说可以尝试

request.headers.set('token', "Bearer ")

方式,但是测试后发现仍行不通,通过各种尝试最后发现是去除request.beforeSend直接设置皆可以

Vue.http.interceptors.push((request, next) => {
  // 请求发送前的处理逻辑
  request.headers.set('token', "Bearer ")
  next((response) => {
    // 请求发送后的处理逻辑
    // 根据请求的状态,response参数会返回给successCallback或errorCallback
    return response
  })
})

如何获取真实的token,

因为全局设置是在main.js中,而token是在登录后才存储下来的能否获取到真实值
1.确保你的token确实存在
2.正常程序中通过this.$cookies.get(“token”)可以获取token的值,因为对vue的认知不够深,不知道在入口文件处如何获取token值,通过多次测试获取解决方案

import Vue from 'vue'
import VueCookies from 'vue-cookies'
Vue.use(VueCookies);
Vue.http.interceptors.push((request, next) => {
  // 请求发送前的处理逻辑
  request.headers.set('Authorization', "Bearer " + VueCookies.get("token"))
  next((response) => {
    // 请求发送后的处理逻辑
    // 根据请求的状态,response参数会返回给successCallback或errorCallback
    return response
  })
})

扩展:vue 配置公共头部(header)

需求:整个项目;每个项目都有头部 但是内容不一样;这种情况我们可以考虑在app.vue中创建公共头部;

App.vue

<template>
  	<div id="app">
	    <div class="header" v-if="isShowHeader" id="headers">
                <span class="title-info">
                        {{headerTitle}}
                 </span> 
	     </div>
	</div>
</template>
<script>
import { mapState } from "vuex";
import home from "../src/components/home";
 
export default {
  name: "App",
  data() {
    return {
 
    };
  },
  computed: {
    // 存储到store状态管理中
    ...mapState({
      headerTitle: state => state.$vux.headerTitle,
    })
  },
 
};
</script>

store.js

    import Vue from 'vue'
    import Vuex from 'vuex'
 
    Vue.use(Vuex)
    const store = new Vuex.Store({  })
    store.registerModule('$vux', { // 名字自己定义
        state: {//设置属性
            headerTitle:'',
        },
        getters:{ // getters 用来获取sate里面存储的数据
 
        },
         mutations: {//更改属性的状态//返回来会有两个状态一个是上面的state,还有一个是返回来的状态(形参),返回之后将我们请求回来的数据赋给state
                 getHeaderTitle(state, obj) {
                state.headerTitle = obj.headerTitle
            },
        }
 
    export default store

main.js

//全局配置
import Vue from "vue";
import App from "./App";
import router from "./router";
 
  store.commit("getHeaderTitle", { headerTitle: to.meta.title });

router.js

import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)
 
export default new Router({
  // mode: "history",
  linkActiveClass: "on",
     routes: [
        {
          path: "/business",
          name: "business",
          component: business,
          meta: {
            title: "粤警监管", // 添加该字段,表示进入这个路由是需要登录的
            keepAlive: true
          }
        },
    ]
})

到此这篇关于通过vue如何设置header的文章就介绍到这了,更多相关vue设置header内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入探究Vue中$nextTick的实现原理

    深入探究Vue中$nextTick的实现原理

    这篇文章主要为大家详细介绍Vue中$nextTick的实现原理,文中的示例代码讲解详细,对我们深入了解Vue有一定的帮助,需要的小伙伴可以参考一下
    2023-06-06
  • Vue实现下拉表格组件

    Vue实现下拉表格组件

    这篇文章主要为大家详细介绍了Vue实现下拉表格组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • vue中bus的使用及踩坑解决

    vue中bus的使用及踩坑解决

    这篇文章主要为大家详细介绍了vue中bus的相关使用以及涉及到的问题与解决,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-08-08
  • vue自定义全局组件实现弹框案例

    vue自定义全局组件实现弹框案例

    这篇文章主要为大家详细介绍了vue自定义全局组件实现弹框案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Vue中使用 Echarts5.0 遇到的一些问题(vue-cli 下开发)

    Vue中使用 Echarts5.0 遇到的一些问题(vue-cli 下开发)

    这篇文章主要介绍了Vue中使用 Echarts5.0 遇到的一些问题(vue-cli 下开发),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • elementui源码学习之仿写一个el-divider组件

    elementui源码学习之仿写一个el-divider组件

    这篇文章主要为大家介绍了elementui源码学习之仿写一个el-divider组件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • vue实现数据控制视图的原理解析

    vue实现数据控制视图的原理解析

    这篇文章主要介绍了vue如何实现的数据控制视图的相关知识,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • Django+vue跨域问题解决的详细步骤

    Django+vue跨域问题解决的详细步骤

    这篇文章主要介绍了Django+vue跨域问题解决的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • Vue2和Vue3中常用组件通信用法分享

    Vue2和Vue3中常用组件通信用法分享

    这篇文章主要为大家整理了Vue3的8种和Vue2的12种组件通信的使用方法,文中的示例代码讲解详细,对我们学习Vue有一定的帮助,值得收藏
    2023-04-04
  • vue实现表格动态嵌入折线图的绘制代码

    vue实现表格动态嵌入折线图的绘制代码

    这篇文章给大家介绍了vue实现表格动态嵌入折线图的绘制方法,文中有详细完整的代码示例攻大家参考,对大家的学习或工作有一定的参考价值,需要的朋友可以参考下
    2023-10-10

最新评论