关于vue中使用全局变量的问题
admin
2024-05-10 17:50:10

先看需求: 点击开始,使用fetch()发送请求,接收数据流.  点击停止,终止fetch()请求。

问题:要想终止fecth() 请求的数据流, 就要销毁new的方法

方法1. 创建存放全局变量的js

在store文件夹中新建js文件config,并填入内容,将其暴露出去

const controller = new AbortController();
const signal = controller.signal;export {signal,controller,
}

在main.js中:

import {signal,controller,
}from "@/store/config.js"Vue.prototype.signal = signal;
Vue.prototype.controller = controller;

这样在vue文件中就可使用了,例如:

this.controller.abort(); // 终止请求

方法1new的方法是手动创建的,每次销毁之后,在不刷新的前提下,是没办法重新new的, 实际操作就是, 点击了开始接收数据流, 点击停止销毁方法,停止接收数据流,   在不刷新页面的前提下想要再次点击开始,接收数据流, 然后就没办法停止了.就只能方法2了

方法2 将new的方法,挂载到window上.

像这样:

window["controller" + (index + 1)] = new AbortController();window["signal" + (index + 1)] =window["controller" + (index + 1)].signal;

我这里的index是循环出来多个,  每次点击开始,就新建一次.

在点击停止的时候就销毁:

   window["controller" + (index + 1)].abort();

这样就非常简便的实现了想要的功能.

哪里写的不对的, 欢迎讨论~

相关内容

热门资讯

7碗家传秘方面条!好吃的流口水... 炸酱面 Monday 材料 半肥瘦肉末500克、六必居黄酱1袋、清水150毫升、京葱1根、老抽1勺...
【文字实录】广东省政府新闻办举... 1月30日,广东省人民政府新闻办公室在广州市广东大厦举行“‘十四五’广东成就”系列主题新闻发布会,主...
去西安旅游,旅行社到底靠不靠谱... 问:现在去西安旅游,跟团是不是很容易踩坑? 答: 不一定,但选错旅行社,踩坑概率确实会明显上升。 从...
酸菜鱼鱼片为何会散?老川菜师傅... 🍽️ 做酸菜鱼时,鱼片用盐腌还是料酒?这是个值得探讨的问题!许多人在烹饪酸菜鱼时,常常因为鱼片煮得不...