axios请求本地json文件——调用路径只支持相对路径形式 & 设置、获取、清除sessionStorage & 跨组件通信之父组件有provide选项提供数据,子组件有inject选项来使用数据

axios请求本地json文件——调用路径只支持相对路径形式 & 设置、获取、清除sessionStorage & 跨组件通信之父组件有provide选项提供数据,子组件有inject选项来使用数据

示例
1.安装axios
npm install axios --save
2.在main.js中引入
import { createApp } from 'vue'
import axios from 'axios'
import VueAxios from 'vue-axios'
const app = createApp(App)
app.config.globalProperties.$http = axios;
app.use(VueAxios, axios)
3.在根目录下的public文件夹data文件夹下新建一个userlist.json文件内容如下
{
    "data":{
        "sucess":200,
        "userList":[
            {
                "success":200,
                "name":"王三",
                "key":0,
                "age":21,
                "address":"海珠区琶洲会展中心"
            },
            {
                "success":200,
                "name":"李五",
                "key":1,
                "age":32,
                "address":"海珠区花城大道北109号"
            }
        ],
        "isShow":true,
        "loginUrl":"http://baidu.com/image",
    }
}
4.在需要请求数据的文件里导入axios
import axios from 'axios'
5.请求
<script lang="ts" setup>
    import axios from 'axios';
    const dataSource: Ref<DataItem[]> = ref([]);  //用户表格数据
    // 获取表格数据
    const getTableList = () => {
       axios.get('http://127.0.0.1:8000/data/userList.json').then((res) => {
        console.log(res, 'res');
        if (res.data.data.sucess == 200) {
          dataSource.value = res.data.data.userList;  
          // data = res.data.data.userList;
         } else {
          alert('数据获取失败');
        }
  });
};
</script>
实例一

src同层级,public文件夹下新建serverConfig.json

public/serverConfig.json

{
   "isShow":true,
   "loginUrl":"http://baidu.com/image", 
}

src/main.ts

import {createApp, ref, provide} from 'vue'
import App from './App'
import axios from '@/utils/request'
const app = createApp(App)
let isShow:any = null

const getConfig = function(){
    axios.get('serverConfig.json').then((result)=>{  // public下一级,只写文件名
        app.provide('isShow',result.data.isShow)
        app.provide('loginUrl',result.data.loginUrl)
        isShow = result.data.isShow
        app.mount('#app')
    }).catch((error)=>{
        console.log(error)
    })
}
getConfig() // 调用声明的全局方法
  • provide方法中第一个参数是key,第二个参数是value

页面使用

index.vue

<script setup>
import {inject, ref, onMounted, watch}
    
let isShow = ref(inject('isShow'))
const loginUrl = inject('loginUrl')

const getKey = () => {
    axios.post(process.env.VUE_API_HOST + '/login/getKey', {}).then((res)=>{
        if(res.data.code == '200'){
            // 设置sessionStorage
            window.sessionStorage.setItem('loginUrl',JSON.stringify(res.data.data))
        }
    })
}
getKey()
    
 // 获取sessionStorage
const loginNewUrl = window.sessionStorage.getItem('loginUrl')    

 // 清除sessionStorage
const clearSession = (store:any) => {
    window.sessionStorage.removeItem('isShow')
}
clearSession(store)
</script>
实例二

src同层级,public文件夹下的static文件夹中,新建userInfo.json

public/static/userInfo.json

{
   "userName":"小明",
   "userId":"Manage01", 
}

public中的JSON文件,在发送axios请求时,不要携带 public 这个目录名

created() {
   axios({
        method: 'get',
        url: '/static/userInfo.json',  // 不用写public,public下两级,需写文件夹名
      }).then((data) => {
        console.log(data)
      })
    },
    methods: {},
  }

搭建的vue项目,要把JSON文件放到项目中的public文件夹中,并且要写绝对路径,这是因为:

  • assets目录中的文件会被webpack处理解析为模块依赖,只支持相对路径形式。build的时候由Webpack解析为模块依赖。
  • public/ 目录下的文件并不会被Webpack处理:它们会直接被复制到最终的打包目录(默认是dist/static)下。
    必须使用绝对路径引用这些文件,这是通过在 项目vue.config.js文件中的 assetsPublicPath 和
    assetsSubDirectory 连接来确定的。 任何放在 public/中文件需要以绝对路径的形式引用:/static/[filename],

所以如果需要引用static目录下的图片及其他资源,应该使用绝对路径。

### Vue3 使用 Axios 获取 Token 的示例 在 Vue3 项目中使用 Axios 获取 Token 主要涉及配置 Axios 实例以及处理认证逻辑。以下是具体实现方式: #### 创建 Axios 实例 为了更好地管理 HTTP 请求,建议创建一个独立的 Axios 实例来设置默认参数和其他全局配置。 ```javascript // request/index.js import axios from &#39;axios&#39;; const service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, // API base_url timeout: 5000 // Request timeout }); export default service; ``` 此代码片段展示了如何初始化带有基础 URL 和超时时间的 Axios 客户端实例[^4]。 #### 登录接口定义 接下来定义用于登录操作的具体函数,该函数会向服务器发送用户名和密码,并接收返回的 Token 数据。 ```typescript // apis/user.ts import service from &#39;@/request/index&#39;; interface ILoginData { username: string, password: string } export function login(data: ILoginData) { return service({ url: &#39;/login&#39;, // 替换成实际API路径 method: &#39;POST&#39;, data // 发送的数据体 }); } ``` 这段 TypeScript 代码描述了一个名为 `login` 的异步函数,它接受用户凭证作为输入并通过 POST 请求将其提交给指定的服务端点以换取访问令牌。 #### 存储与应用 Token 一旦成功获得 Token 后,则需妥善保存以便后续请求携带身份验证信息。通常做法是在本地存储 (localStorage 或 sessionStorage),并在每次发起新请求前自动附加 Authorization 头部字段。 ```javascript // utils/auth.ts import { localStorage } from &#39;@vueuse/core&#39; function setToken(token:string){ window.localStorage.setItem(&#39;token&#39;, token); } function getToken(){ return window.localStorage.getItem(&#39;token&#39;); } export {setToken,getToken}; ``` 上述 JavaScript 函数提供了两个工具方法:一个是用来把接收到的新 Token 放入浏览器缓存;另一个是从那里读取现有记录供其他组件调用[^1]. #### 自动附带 Token 到请求头 为了让所有发出的请求都包含有效的授权凭据,可以在 Axios 拦截器里做统一处理。 ```javascript // request/index.js 继续... service.interceptors.request.use( config =&gt; { const token = getToken(); if (token) { config.headers[&#39;Authorization&#39;] = `Bearer ${token}`; } return config; }, error =&gt; Promise.reject(error) ); export default service; ``` 这里修改了之前创建好的 Axios 实例对象,在其请求拦截链上加入了一段逻辑,确保每一次对外通信都会带上当前用户的鉴权标志&mdash;&mdash;即 Bearer 类型下的 Access Token[^3]. #### 调用 Login 并处理响应 最后一步就是在适当的地方触发这个流程,比如在一个表单提交事件处理器内部完成整个过程。 ```html &lt;template&gt; &lt;!-- ... --&gt; &lt;/template&gt; &lt;script setup lang=&quot;ts&quot;&gt; import { ref } from &#39;vue&#39; import { useRouter } from &#39;vue-router&#39; import { useStore } from &#39;../store&#39; import { login as loginUser } from &#39;@/apis/user&#39; import { setToken } from &#39;@/utils/auth&#39; const router = useRouter() const store = useStore() async function handleLogin() { try { let res = await loginUser({username:&#39;admin&#39;,password:&#39;123&#39;}) console.log(res.data.token); // 打印出服务端返回的结果中的 token 字段 setToken(res.data.token); // 将获取到的 token 设置进 storage 中去 router.push(&#39;/dashboard&#39;); // 成功后跳转至仪表盘页面或其他受保护路由 } catch(err){ alert(`登录失败:${err.message}`); // 如果发生错误则给出提示信息 } } &lt;/script&gt; ``` 以上模板部分省略不显,重点在于脚本标签内的业务逻辑编写。当点击按钮或者其他交互行为激活 `handleLogin()` 方法执行时,便会依照既定顺序依次尝试连接远程主机、解析 JSON 格式的回复内容并将其中的关键数据项提取出来加以利用[^2].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值