用Vuex存储可配置下载的ip地址(用XML进行ajax请求配置文件)

1.在public文件夹下创建一个名为Configuration的文件在创建一个Configuration.txt里面就放IP地址(这里的名字可以随便命名一定性的被人解读文件含义)

例如:

javascript 复制代码
http://172.171.208.1:8003

2.在store文件夹中创建一个名为 ajaxModule.js 的 Vuex 模块:

javascript 复制代码
const state = {
    changeIp: ''//参数
};
const mutations = {
    setChangeIp(state, ip) {
        state.changeIp = ip;
    }
};
const getters = {
    changeIp: state => state.changeIp,
};
const actions = {
    fetchChangeIp({ commit }) {
        var xhttp = new XMLHttpRequest();
        xhttp.onreadystatechange = function () {
            if (this.readyState == 4 && this.status == 200) {
                var Changeid = this.responseText; 
                commit('setChangeIp', Changeid);
            }
        };
        xhttp.open("GET", "../../Configuration/Configuration.txt", true);
        xhttp.send();
    }
};
export default {
    namespaced: true,/// 添加这一行启用命名空间
    state,
    mutations,
    actions,
    getters
};

3.在您的store中index.js引入ajaxModule模块

javascript 复制代码
import Vue from 'vue'
import Vuex from 'vuex'
import ajaxModule from './ajaxModule';

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
  },
  getters: {
  },
  mutations: {
  },
  actions: {
  },
  modules: {
    ajax:ajaxModule//引入模块
  }
})

4.在全局页面中调用该 Vuex 模块:

javascript 复制代码
<template>
  <div>
    <p>Change IP: {{ changeIp }}</p>
  </div>
</template>

<script>
import { mapActions, mapGetters } from "vuex"; //引入vuex模块

export default {
  computed: {
    // 添加命名空间 'ajax' 到 mapGetters
    ...mapGetters("ajax", ["changeIp"]),
  },
  methods: {
    // 同样,添加命名空间 'ajax' 到 mapActions
    ...mapActions("ajax", ["fetchChangeIp"]),

    frontDownload() {
      var a = document.createElement("a"); // 创建一个<a></a>标签
      var peizhiurl = this.changeIp; //获取到配置文件的ip地址
      a.href = peizhiurl + "/ViebPlugin.exe"; //拼接起来就可以了http://172.17.208.1:8003/ViebPlugin.exe
      a.download = "VideoWebPlugin.exe"; //
      a.style.display = "none"; // 障眼法藏起来a标签
      document.body.appendChild(a); // 将a标签追加到文档对象中
      a.click(); // 模拟点击了a标签,会触发a标签的href的读取,浏览器就会自动下载了
      a.remove(); // 一次性的,用完就删除a标签
    },
  },
};
</script>
相关推荐
小飞侠在吗12 分钟前
vue props
前端·javascript·vue.js
用户841794814562 小时前
vxe-gantt 甘特图实现产品进度列表,自定义任务条样式和提示信息
vue.js
VX:Fegn08954 小时前
计算机毕业设计|基于Java人力资源管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·课程设计
老华带你飞4 小时前
健身房|基于springboot + vue健身房管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
JIngJaneIL4 小时前
基于Java酒店预约系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
一位搞嵌入式的 genius6 小时前
Vue实例挂载:从原理到项目实践的全维度解析
前端·javascript·vue.js·前端框架
cindershade6 小时前
Vue 3 Keep-Alive 深度实践:从原理到最佳实践
vue.js·vue-router
m0_740043737 小时前
Vue Router中获取路由参数d两种方式:$route.query和$route.params
前端·javascript·vue.js
Shirley~~7 小时前
vite的tersor在lib库模式下不生效问题
javascript·vue.js·ecmascript
小飞侠在吗7 小时前
vue 生命周期
前端·javascript·vue.js