js 对url进行某个参数的删除,并返回url 两种情况

本文介绍了一种实用的JavaScript函数,用于从当前页面或特定URL中删除指定名称的参数。通过解析URL并重构查询字符串,该函数能有效移除不需要的参数,适用于网页应用的动态链接管理和优化。

1对当前页面的url进行操作

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

function funcUrlDel(name){

        var loca = window.location;

        var baseUrl = loca.origin + loca.pathname + "?";

        var query = loca.search.substr(1);

        if (query.indexOf(name)>-1) {

            var obj = {}

            var arr = query.split("&");

            for (var i = 0; i < arr.length; i++) {

                arr[i] = arr[i].split("=");

                obj[arr[i][0]] = arr[i][1];

            };

            delete obj[name];

            var url = baseUrl + JSON.stringify(obj).replace(/[\"\{\}]/g,"").replace(/\:/g,"=").replace(/\,/g,"&");

            return url

        }else{

            return window.location.href;

        };

    }

console.log(funcUrlDel('tt'));

2 对特定的url进行处理

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

function urlDelP(url,name){

        var urlArr = url.split('?');

        if(urlArr.length>1 && urlArr[1].indexOf(name)>-1){

            var query = urlArr[1];

            var obj = {}

            var arr = query.split("&");

            for (var i = 0; i < arr.length; i++) {

                arr[i] = arr[i].split("=");

                obj[arr[i][0]] = arr[i][1];

            };

            delete obj[name];

            var urlte = urlArr[0] +'?'+ JSON.stringify(obj).replace(/[\"\{\}]/g,"").replace(/\:/g,"=").replace(/\,/g,"&");

            return urlte;

        }else{

            return url;

        };

    }

console.log(urlDelP('http://test.com/test?tt=3&kk=6','tt'));

console.log(urlDelP('http://test.com/test?kk=6&ll=88','tt'));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值