首页 > 其他分享 >vue.js客服系统实时聊天项目开发(六)获取URL中的GET参数(支持/#/?单页锚点hash模式)

vue.js客服系统实时聊天项目开发(六)获取URL中的GET参数(支持/#/?单页锚点hash模式)

时间:2023-01-19 23:33:42浏览次数:74  
标签:vue hash val 单页 substring URL 参数 key var

封装一个函数获取URL中的GET参数

需要支持锚点链接例如:http://localhost:8080/#/chatApp?ent_id=5

具体来说

    var query = window.location.search.substring(1);
    var hash = window.location.hash.substring(1);

获取到URL在的参数

使用substring方法获取到URL中的查询字符串(即从"?"开始的部分)。然后使用split方法将查询字符串拆分成一个键值对数组。接着,使用map方法遍历这个数组,并将每一个键值对添加到一个对象中。最后,使用typeof语句判断传入的参数在这个对象中是否存在,如果存在则返回该参数的值,否则返回空字符串。

function getQuery(key) {
    // 获取所有参数
    var query = window.location.search.substring(1);
    var hash = window.location.hash.substring(1);
    // 如果锚点后面有参数,把锚点后面的参数加入到search参数中
    if(hash.indexOf("?") > -1){
        query += "&" + hash.split("?")[1];
    }
    var key_values = query.split("&");
    var params = {};
    // 遍历参数并存入params对象
    key_values.map(function (key_val){
        var key_val_arr = key_val.split("=");
        params[key_val_arr[0]] = key_val_arr[1];
    });
    // 如果找到了key对应的参数,返回对应值
    if(typeof params[key]!="undefined"){
        return params[key];
    }
    // 如果没找到,返回空字符串
    return "";
}

 

唯一在线客服系统

https://gofly.v1kf.com

标签:vue,hash,val,单页,substring,URL,参数,key,var
From: https://www.cnblogs.com/taoshihan/p/17062298.html

相关文章

  • Vue 中如何监测数组的变化?
    在Vue中,如果直接对数组进行操作,比如使用下标直接修改元素,Vue是无法监测到这种变化的,导致无法触发视图更新。针对该问题,总结如下解决方法:一、使用Vue.js提供的方法来......
  • Vue 中 data 为什么必须是一个函数?
    在Vue中,每个组件都是一个对象,当多个实例共享同一对象时,它们将共享相同的状态。如果data不是一个函数并且是一个对象,那么所有组件实例将共享相同的data对象,这样就会导......
  • Vue2.0项目引入字体库font-awesome
    1.安装依赖npminstallfont-awesome--save2.引入依赖可以选择全局引入或局部引入import'font-awesome/css/font-awesome.min.css';3.使用方式3.1.基本图标......
  • VueUse实用工具
    1.安装npmi@vueuse/core2.使用useClipboard剪贴板<scriptsetuplang="ts">import{ref}from'vue'import{useClipboard,usePermission}from'@vue......
  • 使用 IDEA 工具打开vue/react/node项目
    1.IDEA在官网上下载社区免费版的https://www.jetbrains.com/zh-cn/idea/download/#section=mac下载完成后,一直点击next安装即可2.安装完成后点击open打开gitcl......
  • Android 使用HttpURLConnection
    修改activity_main.xml中的代码,如下所示:<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"an......
  • vant+vue3自定义主题
    很多系统都会有切换主题的功能,现在做的是一个vant的项目,特地记录一下这里面用到的css3的一个技术,也就是变量,css3的var()和自定义变量,具体使用可百度大题逻辑是这样 ......
  • Vuw2和Vue3如何使用ref获取元素节点?
    Vue2中<template><divid="app"><divref="echohye">新年快乐</div></div></template><script>exportdefault{mounted(){console.log(this.$ref......
  • 解决:windows下php curl https时 SSL operation failed with code 1. OpenSSL Error me
    下载证书curl-ExtractCACertsfromMozillahttps://curl.se/docs/caextract.html 配置php.ini,把路径放上去  搞定收工......
  • Spring远程处理(通过Burlap示例)
    Houssian和Burlap均由Coucho提供。借助于 BurlapServiceExporter 和 BurlapProxyFactoryBean 类,我们可以实现burlap提供的远程服务。Burlap的示例与Burlap相同,您只需......