URLパラメータを変更する


189

私はこのURLを持っています:

site.fwx?position=1&archiveid=5000&columns=5&rows=20&sorting=ModifiedTimeAsc

「行」のURLパラメータ値を指定した値に変更できるようにする必要があります。たとえば、10としましょう。「行」が存在しない場合は、URLの最後に追加して、値はすでに指定しています(10)。


2
軽量でプラグイン不要の回答:stackoverflow.com/a/10997390/11236
ripper234

11
2013年だとは信じられません。コアブラウザーライブラリに組み込まれているような、より良い方法はありません。
タイラーコリアー2013年

最新のソリューションについての私の答えを参照してください:stackoverflow.com/a/19965480/64949
Sindre Sorhus

6
@TylerCollier 2015年半ば、今でも何もない:(
Tejas Manohar

3
私たちはそこに取得しているように思える... developer.mozilla.org/en-US/docs/Web/API/URLSearchParams/...
クリス・

回答:


111

Sujoyのコードを拡張して関数を作成しました。

/**
 * http://stackoverflow.com/a/10997390/11236
 */
function updateURLParameter(url, param, paramVal){
    var newAdditionalURL = "";
    var tempArray = url.split("?");
    var baseURL = tempArray[0];
    var additionalURL = tempArray[1];
    var temp = "";
    if (additionalURL) {
        tempArray = additionalURL.split("&");
        for (var i=0; i<tempArray.length; i++){
            if(tempArray[i].split('=')[0] != param){
                newAdditionalURL += temp + tempArray[i];
                temp = "&";
            }
        }
    }

    var rows_txt = temp + "" + param + "=" + paramVal;
    return baseURL + "?" + newAdditionalURL + rows_txt;
}

関数呼び出し:

var newURL = updateURLParameter(window.location.href, 'locId', 'newLoc');
newURL = updateURLParameter(newURL, 'resId', 'newResId');

window.history.replaceState('', '', updateURLParameter(window.location.href, "param", "value"));

URLのアンカーも処理する更新バージョン。

function updateURLParameter(url, param, paramVal)
{
    var TheAnchor = null;
    var newAdditionalURL = "";
    var tempArray = url.split("?");
    var baseURL = tempArray[0];
    var additionalURL = tempArray[1];
    var temp = "";

    if (additionalURL) 
    {
        var tmpAnchor = additionalURL.split("#");
        var TheParams = tmpAnchor[0];
            TheAnchor = tmpAnchor[1];
        if(TheAnchor)
            additionalURL = TheParams;

        tempArray = additionalURL.split("&");

        for (var i=0; i<tempArray.length; i++)
        {
            if(tempArray[i].split('=')[0] != param)
            {
                newAdditionalURL += temp + tempArray[i];
                temp = "&";
            }
        }        
    }
    else
    {
        var tmpAnchor = baseURL.split("#");
        var TheParams = tmpAnchor[0];
            TheAnchor  = tmpAnchor[1];

        if(TheParams)
            baseURL = TheParams;
    }

    if(TheAnchor)
        paramVal += "#" + TheAnchor;

    var rows_txt = temp + "" + param + "=" + paramVal;
    return baseURL + "?" + newAdditionalURL + rows_txt;
}

これを機能させることができないようです。これが私のコードです:jsfiddle.net/Draven/tTPYL/1 URLは次のようにhttp://www.domain.com/index.php?action=my_action&view-all=Yesなり、「view-all」の値を変更する必要があります。閉鎖された私のSOの質問:stackoverflow.com/questions/13025880/...
Draven

本気ですか?それは私にとっては簡単に機能しました。ここをチェックしてください:jsfiddle.net/mw49a
Adil Malik

1
「i = 0」の代わりに「var i = 0」を使用して、iをグローバル変数として作成/変更しないようにします。
ジョナサンアキノ2014

1
この関数に関する他のいくつかの問題:(1)paramValはURIエンコードされません。(2)paramValがnullの場合、foo = nullになります。これはfoo =である必要があります(またはさらに良いのは、fooを完全に削除することです)。
ジョナサンアキノ2014

これは私の人生をとても簡単にしました。どうもありがとう!
Boydenhartog

97

クエリプラグインが必要だと思います。

例えば:

window.location.search = jQuery.query.set("rows", 10);

これは、行の現在の状態に関係なく機能します。


Mofle、それは、クエリプラグインがdecodeURIComponentを使用し、decodeURIComponent( "%F8")が無効であるためです。
Matthew Flaschen 2009

2
URLから奇妙なものを取り出してください。または、言い換えると、「有効なUTF-8文字のみを使用するようにクエリ文字列を変更してください」。:) F8だけでは有効なUTF-8文字ではありません。
マシューフラッシェン2009

このプラグインからベースURLを取得する方法はありますか?私のURL「の場合たとえば、youtube.com/watch?v=PZootaxRh3M」、「を取得youtube.com/watch
マット・ノリス

3
@レイス、そのためのプラグインは必要ありません。それだけwindow.location.pathnameです。
マシューFlaschen

2
あなたは、このためのプラグインを必要としませんが、正しい答えは@MattNorris:window.location.host + window.location.pathnameあなたのケースでは、それは「www.youtube.com/watch」になります
nktssh

68

たくさん学んだ後、4年後に私の質問に答える。特に、すべてにjQueryを使用するべきではありません。クエリ文字列を解析/文字列化できる単純なモジュールを作成しました。これにより、クエリ文字列を簡単に変更できます。

次のようにquery-stringを使用できます。

// parse the query string into an object
var q = queryString.parse(location.search);
// set the `row` property
q.rows = 10;
// convert the object to a query string
// and overwrite the existing query string
location.search = queryString.stringify(q);

1
うわーこれは見事にシンプルなソリューションです。ありがとうございました!
jetlej 2014年

これはチャンピオンのように機能します!Sindre Thankに感謝します(「クエリ文字列/index.js」を縮小し、それをjsの下部に貼り付けるだけです)
Ronnie Royston

1
そのためだけに追加のライブラリを用意するのは少し余分に思われます...
ゴッドファーザー

63

純粋なjsのクイック小さなソリューション、プラグインは必要ありません:

function replaceQueryParam(param, newval, search) {
    var regex = new RegExp("([?;&])" + param + "[^&;]*[;&]?");
    var query = search.replace(regex, "$1").replace(/&$/, '');

    return (query.length > 2 ? query + "&" : "?") + (newval ? param + "=" + newval : '');
}

次のように呼び出します。

 window.location = '/mypage' + replaceQueryParam('rows', 55, window.location.search)

または、同じページにとどまり、複数のパラメータを置き換える場合:

 var str = window.location.search
 str = replaceQueryParam('rows', 55, str)
 str = replaceQueryParam('cols', 'no', str)
 window.location = window.location.pathname + str

編集、おかげでルーク:完全にパラメータを削除するには、合格falseまたはnull値のため:replaceQueryParam('rows', false, params)0 も偽物なので、指定してください'0'


2
また、出力から使用済みのパラメーターを削除するには、次のようにします。str = replaceQueryParam( 'oldparam'、false、str)-基本的に、偽の型の値を入力します
Luke Wenke

1
問題、正当な理由なく、私のパラメータを重複が、この同様のソリューションをチェックアウトしたstackoverflow.com/a/20420424/3160597
azerafati

@Bludreamそのコードは何年もプロダクションで機能しています。私はそれがまだパラメータを複製するのを見ていません。再現またはより建設的な情報を投稿できますか?
ブロンソン2015

@Bludream理解しました。これは、リンクしたスクリプトが重複したパラメータを追加しているスクリプトです。:)
ブロンソン2015

1
@dVyper正解。偽の値はパラメーターを完全に削除します。代わりに、整数0の使用テキスト「0」
ブロンソン

62

Ben Almanには、jquery querystring / urlプラグインがあり、クエリ文字列を簡単に操作できます。

要求通り-

ここに彼のテストページに行く

firebugで、コンソールに次のように入力します

jQuery.param.querystring(window.location.href, 'a=3&newValue=100');

次の修正されたURL文字列を返します

http://benalman.com/code/test/js-jquery-url-querystring.html?a=3&b=Y&c=Z&newValue=100#n=1&o=2&p=3

aのクエリ文字列値がXから3に変更され、新しい値が追加されていることに注意してください。

次に、新しいURL文字列を使用できますが、たとえばdocument.location = newUrlを使用したり、アンカーリンクを変更したりできます。


4
jQuery.queryStringではなくjQuery.param.querystringではありませんか?
Petr Peller、2010年

12
TypeError: jQuery.param.querystring is not a function
TMS

1
'TypeError'を回避するには、jQuery.queryString(window.location.href、 'a = 3&newValue = 100')
code-gijoe

2
あなたが呼び出す必要がありますjQuery.param.querystring。彼らはライブラリをリファクタリングしたと思います。
Wu

これらの機能はどちらも存在しません。window.location.searchを手動で更新したい。ページを再描画したくない場合は、ページが変更されるため、さらに難しくなります。
2013

38

これに対する最新のアプローチは、ネイティブの標準ベースのURLSearchParamsを使用することです。ポリフィルが利用可能な IEを除き、すべての主要ブラウザでサポートされています

const paramsString = "site.fwx?position=1&archiveid=5000&columns=5&rows=20&sorting=ModifiedTimeAsc"
const searchParams = new URLSearchParams(paramsString);
searchParams.set('rows', 10);
console.log(searchParams.toString()); // return modified string.

1
本当にいいでしょう...しかし、IEがそれをまったくサポートしていないので、そうではありません、そしてそのような小さなものにポリフィルを使用することは完全に問題外です。
フォースバーグ

1
これはまた、元のparamsStringを完全にURLエンコードします。そのため、site.fwx%3Fposition=1&archiveid=5000&columns=5&rows=10&sorting=ModifiedTimeAsc手動で作成した場合に作成したものとは異なるため、結果は混乱を招きます...
Ben Wheeler

1
それを使用する方法の例を見るといいでしょう。つまり、現在のページからparams文字列を取得する方法とその後に設定する方法
ゴッドファーザー、

27

あなたは通常のJSでもそれを行うことができます

var url = document.URL
var newAdditionalURL = "";
var tempArray = url.split("?");
var baseURL = tempArray[0];
var aditionalURL = tempArray[1]; 
var temp = "";
if(aditionalURL)
{
var tempArray = aditionalURL.split("&");
for ( var i in tempArray ){
    if(tempArray[i].indexOf("rows") == -1){
            newAdditionalURL += temp+tempArray[i];
                temp = "&";
            }
        }
}
var rows_txt = temp+"rows=10";
var finalURL = baseURL+"?"+newAdditionalURL+rows_txt;

いいね!これを取り、関数に変更しました。現在のURL、探しているパラメーター名、新しい値、およびパラメーターがクエリ文字列に現在追加されていない場合にクエリ文字列に追加するかどうかを伝えるブール値を送信します。関数は変更されたURLを返します。
Gromer

Gormer、その機能を他の人と共有する必要があります:)
Adil Malik

素晴らしいスニペット。私もそれを自分のユースケースの関数に変えました。共有してくれてありがとう!+1
robabby 2012

18

これは、URLパラメータを変更する最新の方法です。

function setGetParam(key,value) {
  if (history.pushState) {
    var params = new URLSearchParams(window.location.search);
    params.set(key, value);
    var newUrl = window.location.protocol + "//" + window.location.host + window.location.pathname + '?' + params.toString();
    window.history.pushState({path:newUrl},'',newUrl);
  }
}

2
このソリューションは現在Internet Explorer 11ではサポートされていません:caniuse.com/#search=URLSearchParams
WoIIe

同じ回答があなたの半年前に@Alisterによって返信されました
FantomX1

10

文字列操作の実行可能な代替手段は、htmlを設定しformrows要素の値を変更することでしょうか?

それで、htmlそれはのようなものです

<form id='myForm' target='site.fwx'>
    <input type='hidden' name='position' value='1'/>
    <input type='hidden' name='archiveid' value='5000'/>
    <input type='hidden' name='columns' value='5'/>
    <input type='hidden' name='rows' value='20'/>
    <input type='hidden' name='sorting' value='ModifiedTimeAsc'/>
</form>

次のJavaScriptを使用してフォームを送信します

var myForm = document.getElementById('myForm');
myForm.rows.value = yourNewValue;
myForm.submit();

おそらくすべての状況に適しているわけではありませんが、URL文字列を解析するよりも良いかもしれません。


それは賢い問題です。
icarito 2018年

7

あなたはこの私のライブラリを使用して仕事をすることができます:https//github.com/Mikhus/jsurl

var url = new Url('site.fwx?position=1&archiveid=5000&columns=5&rows=20&sorting=ModifiedTimeAsc');
url.query.rows = 10;
alert( url);

4

2020ソリューション:変数を設定するnullundefined、値を渡すか、値に渡すとitiを削除します。

var setSearchParam = function(key, value) {
    if (!window.history.pushState) {
        return;
    }

    if (!key) {
        return;
    }

    var url = new URL(window.location.href);
    var params = new window.URLSearchParams(window.location.search);
    if (value === undefined || value === null) {
        params.delete(key);
    } else {
        params.set(key, value);
    }

    url.search = params;
    url = url.toString();
    window.history.replaceState({url: url}, null, url);
}

URLSearchParamsすべての主要ブラウザの最新バージョン(2020)では機能しないことに注意してください
Oliver Schimmer


IE11を除くすべての主要なブラウザーでサポートされています:caniuse.com/#search=URLSearchParams
Luis Paulo Lohmann

サポートが開始された場合でも、URLSearchParamsと同じ回答がこの質問で少なくとも3回回答されています。回答は1月15日17時15分24秒、6月14日18時15分54秒、3月1日19時12:46、投稿前に誰も返信を読んでいないかのように
FantomX1

すべての投稿には、解決する必要がある小さな問題があります。したがって、ユーザーに投票させて最高のものを選びましょう。
Alper Ebicoglu

3

任意の選択で機能する小さなヘルパー関数を作成しました。必要なのは、クラス「redirectOnChange」を任意の選択要素に追加することだけです。これにより、選択のIDと値に等しい、新しい/変更されたクエリ文字列パラメーターでページがリロードされます。例:

<select id="myValue" class="redirectOnChange"> 
    <option value="222">test222</option>
    <option value="333">test333</option>
</select>

上記の例では、「?myValue = 222」または「?myValue = 333」を追加し(または他のパラメーターが存在する場合は「&」を使用)、ページを再読み込みします。

jQuery:

$(document).ready(function () {

    //Redirect on Change
    $(".redirectOnChange").change(function () {
        var href = window.location.href.substring(0, window.location.href.indexOf('?'));
        var qs = window.location.href.substring(window.location.href.indexOf('?') + 1, window.location.href.length);
        var newParam = $(this).attr("id") + '=' + $(this).val();

        if (qs.indexOf($(this).attr("id") + '=') == -1) {
            if (qs == '') {
                qs = '?'
            }
            else {
                qs = qs + '&'
            }
            qs = qs + newParam;

        }
        else {
            var start = qs.indexOf($(this).attr("id") + "=");
            var end = qs.indexOf("&", start);
            if (end == -1) {
                end = qs.length;
            }
            var curParam = qs.substring(start, end);
            qs = qs.replace(curParam, newParam);
        }
        window.location.replace(href + '?' + qs);
    });
});

このページで
群を抜い

2

ここで私はアディル・マリクの答えを取り入れて、私が特定した3つの問題を修正しました。

/**
 * Adds or updates a URL parameter.
 *
 * @param {string} url  the URL to modify
 * @param {string} param  the name of the parameter
 * @param {string} paramVal  the new value for the parameter
 * @return {string}  the updated URL
 */
self.setParameter = function (url, param, paramVal){
  // http://stackoverflow.com/a/10997390/2391566
  var parts = url.split('?');
  var baseUrl = parts[0];
  var oldQueryString = parts[1];
  var newParameters = [];
  if (oldQueryString) {
    var oldParameters = oldQueryString.split('&');
    for (var i = 0; i < oldParameters.length; i++) {
      if(oldParameters[i].split('=')[0] != param) {
        newParameters.push(oldParameters[i]);
      }
    }
  }
  if (paramVal !== '' && paramVal !== null && typeof paramVal !== 'undefined') {
    newParameters.push(param + '=' + encodeURI(paramVal));
  }
  if (newParameters.length > 0) {
    return baseUrl + '?' + newParameters.join('&');
  } else {
    return baseUrl;
  }
}

1

これが私がすることです。私のeditParams()関数を使用して、パラメーターを追加、削除、または変更してから、組み込みのreplaceState()関数を使用してURLを更新できます。

window.history.replaceState('object or string', 'Title', 'page.html' + editParams('sorting', ModifiedTimeAsc));


// background functions below:

// add/change/remove URL parameter
// use a value of false to remove parameter
// returns a url-style string
function editParams (key, value) {
  key = encodeURI(key);

  var params = getSearchParameters();

  if (Object.keys(params).length === 0) {
    if (value !== false)
      return '?' + key + '=' + encodeURI(value);
    else
      return '';
  }

  if (value !== false)
    params[key] = encodeURI(value);
  else
    delete params[key];

  if (Object.keys(params).length === 0)
    return '';

  return '?' + $.map(params, function (value, key) {
    return key + '=' + value;
  }).join('&');
}

// Get object/associative array of URL parameters
function getSearchParameters () {
  var prmstr = window.location.search.substr(1);
  return prmstr !== null && prmstr !== "" ? transformToAssocArray(prmstr) : {};
}

// convert parameters from url-style string to associative array
function transformToAssocArray (prmstr) {
  var params = {},
      prmarr = prmstr.split("&");

  for (var i = 0; i < prmarr.length; i++) {
    var tmparr = prmarr[i].split("=");
    params[tmparr[0]] = tmparr[1];
  }
  return params;
}

コメントのない反対票?コードの何が問題になっていますか?それは多くの状況で素晴らしい働きをします。
Bobb Fwed 2014

1

私の解決策:

const setParams = (data) => {
    if (typeof data !== 'undefined' && typeof data !== 'object') {
        return
    }

    let url = new URL(window.location.href)
    const params = new URLSearchParams(url.search)

    for (const key of Object.keys(data)) {
        if (data[key] == 0) {
            params.delete(key)
        } else {
            params.set(key, data[key])
        }
    }

    url.search = params
    url = url.toString()
    window.history.replaceState({ url: url }, null, url)
}

次に、「setParams」を呼び出して、設定するデータを含むオブジェクトを渡します。

例:

$('select').on('change', e => {
    const $this = $(e.currentTarget)
    setParams({ $this.attr('name'): $this.val() })
})

私の場合、変更時にhtml select入力を更新する必要があり、値が「0」の場合はパラメーターを削除しました。オブジェクトキーも「null」の場合は、関数を編集してURLからパラメータを削除できます。

これがうまくいくことを願っています


あなたの前にURLSearchParamsで同じ答えがすでに2つあります。投稿日:1月15日17時15分24

0

スジョイの答えの別のバリエーション。変数名を変更し、名前空間ラッパーを追加しました:

window.MyNamespace = window.MyNamespace  || {};
window.MyNamespace.Uri = window.MyNamespace.Uri || {};

(function (ns) {

    ns.SetQueryStringParameter = function(url, parameterName, parameterValue) {

        var otherQueryStringParameters = "";

        var urlParts = url.split("?");

        var baseUrl = urlParts[0];
        var queryString = urlParts[1];

        var itemSeparator = "";
        if (queryString) {

            var queryStringParts = queryString.split("&");

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

                if(queryStringParts[i].split('=')[0] != parameterName){

                    otherQueryStringParameters += itemSeparator + queryStringParts[i];
                    itemSeparator = "&";
                }
            }
        }

        var newQueryStringParameter = itemSeparator + parameterName + "=" + parameterValue;

        return baseUrl + "?" + otherQueryStringParameters + newQueryStringParameter;
    };

})(window.MyNamespace.Uri);

使用量は次のとおりです。

var changedUrl = MyNamespace.Uri.SetQueryStringParameter(originalUrl, "CarType", "Ford");

0

JavaScriptでURLクエリパラメータを取得および設定するためライブラリも作成しました。

以下はその使用例です。

var url = Qurl.create()
  , query
  , foo
  ;

キー、または追加/変更/削除により、クエリパラメータをオブジェクトとして取得します。

// returns { foo: 'bar', baz: 'qux' } for ?foo=bar&baz=qux
query = url.query();

// get the current value of foo
foo = url.query('foo');

// set ?foo=bar&baz=qux
url.query('foo', 'bar');
url.query('baz', 'qux');

// unset foo, leaving ?baz=qux
url.query('foo', false); // unsets foo


-1

私はこれが古い質問であることを知っています。上記の関数を拡張して、クエリパラメータを追加または更新しました。それでも純粋なJSソリューションのみ。

                      function addOrUpdateQueryParam(param, newval, search) {

                        var questionIndex = search.indexOf('?');

                        if (questionIndex < 0) {
                            search = search + '?';
                            search = search + param + '=' + newval;
                            return search;
                        }

                        var regex = new RegExp("([?;&])" + param + "[^&;]*[;&]?");
                        var query = search.replace(regex, "$1").replace(/&$/, '');

                        var indexOfEquals = query.indexOf('=');

                        return (indexOfEquals >= 0 ? query + '&' : query + '') + (newval ? param + '=' + newval : '');
                    }

-1

私の関数はパラメータの削除をサポートしています

function updateURLParameter(url, param, paramVal, remove = false) {
        var newAdditionalURL = '';
        var tempArray = url.split('?');
        var baseURL = tempArray[0];
        var additionalURL = tempArray[1];
        var rows_txt = '';

        if (additionalURL)
            newAdditionalURL = decodeURI(additionalURL) + '&';

        if (remove)
            newAdditionalURL = newAdditionalURL.replace(param + '=' + paramVal, '');
        else
            rows_txt = param + '=' + paramVal;

        window.history.replaceState('', '', (baseURL + "?" + newAdditionalURL + rows_txt).replace('?&', '?').replace('&&', '&').replace(/\&$/, ''));
    }

-1

私は、現在のURLクエリパラメータの読み取りと更新を処理する単純なモジュールを作成しました。

使用例:

import UrlParams from './UrlParams'

UrlParams.remove('foo') //removes all occurences of foo=?
UrlParams.set('foo', 'bar') //set all occurences of foo equal to bar
UrlParams.add('foo', 'bar2') //add bar2 to foo result: foo=bar&foo=bar2
UrlParams.get('foo') //returns bar
UrlParams.get('foo', true) //returns [bar, bar2]

これがUrlParams。(js / ts)という名前の私のコードです:

class UrlParams {

    /**
     * Get params from current url
     * 
     * @returns URLSearchParams
     */
    static getParams(){
        let url = new URL(window.location.href)
        return new URLSearchParams(url.search.slice(1))
    }

    /**
     * Update current url with params
     * 
     * @param params URLSearchParams
     */
    static update(params){
        if(`${params}`){
            window.history.replaceState({}, '', `${location.pathname}?${params}`)
        } else {
            window.history.replaceState({}, '', `${location.pathname}`)
        }
    }

    /**
     * Remove key from url query
     * 
     * @param param string
     */
    static remove(param){
        let params = this.getParams()
        if(params.has(param)){
            params.delete(param)
            this.update(params)
        }
    }

    /**
     * Add key value pair to current url
     * 
     * @param key string
     * @param value string
     */
    static add(key, value){
        let params = this.getParams()
        params.append(key, value)
        this.update(params)
    }

    /**
     * Get value or values of key
     * 
     * @param param string
     * @param all string | string[]
     */
    static get(param, all=false){
        let params = this.getParams()
        if(all){
            return params.getAll(param)
        }
        return params.get(param)
    }

    /**
     * Set value of query param
     * 
     * @param key string
     * @param value string
     */
    static set(key, value){
        let params = this.getParams()
        params.set(key, value)
        this.update(params)
    }

}
export default UrlParams
export { UrlParams }

あなたが言及したのと同じ返信がすでに4件投稿されています。17年1月15日15:24に回答、6月14日18:15に回答、3月1日19:12に回答、6月14日19に7に回答: 20、投稿する前に誰も答えを読んでいないかのように
FantomX1

-2
     // usage: clear ; cd src/js/node/js-unit-tests/01-set-url-param ; npm test ; cd -
     // prereqs: , nodejs , mocha
     // URI = scheme:[//authority]path[?paramName1=paramValue1&paramName2=paramValue2][#fragment]
     // call by: uri = uri.setUriParam("as","md")
     String.prototype.setUriParam = function (paramName, paramValue) {
        var uri = this
        var fragment = ( uri.indexOf('#') === -1 ) ? '' : uri.split('#')[1]
        uri = ( uri.indexOf('#') === -1 ) ? uri : uri.split('#')[0]
        if ( uri.indexOf("?") === -1 ) { uri = uri + '?&' }
        uri = uri.replace ( '?' + paramName , '?&' + paramName)
        var toRepl = (paramValue != null) ? ('$1' + paramValue) : ''
        var toSrch = new RegExp('([&]' + paramName + '=)(([^&#]*)?)')
        uri = uri.replace(toSrch,toRepl)
        if (uri.indexOf(paramName + '=') === -1 && toRepl != '' ) {
           var ampersandMayBe = uri.endsWith('&') ? '' : '&'
           uri = uri + ampersandMayBe + paramName + "=" + String(paramValue)
        }
        uri = ( fragment.length == 0 ) ? uri : (uri+"#"+fragment) //may-be re-add the fragment
        return uri
     }

     var assert = require('assert');
     describe('replacing url param value', function () {

        // scheme://authority/path[?p1=v1&p2=v2#fragment
        // a clean url
        it('http://org.com/path -> http://org.com/path?&prm=tgt_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ? with num value
        it('http://org.com/path?prm=src_v -> http://org.com/path?&prm=tgt_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?bid=57'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ? but string value
        it('http://org.com/path?prm=src_v -> http://org.com/path?&prm=tgt_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?bid=boo-bar'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=boo-bar-baz'
           var uriActual = uri.setUriParam("bid","boo-bar-baz")
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ?& but string value
        it('http://org.com/path?&prm=src_v -> http://org.com/path?&prm=tgt_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=5'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ? with other param
        it('http://org.com/path?prm=src_v&other_p=other_v -> http://org.com/path?&prm=tgt_v&other_p=other_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?bid=5&other_p=other_v'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10&other_p=other_v'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ?& with other param
        it('http://org.com/path?&prm=src_v&other_p=other_v -> http://org.com/path?&prm=tgt_v&other_p=other_v', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=5&other_p&other_v'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10&other_p&other_v'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ? with other param with fragment
        it('http://org.com/path?prm=src_v&other_p=other_v#f -> http://org.com/path?&prm=tgt_v&other_p=other_v#f', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?bid=5&other_p=other_v#f'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10&other_p=other_v#f'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // has the url param existing after the ?& with other param with fragment
        it('http://org.com/path?&prm=src_v&other_p=other_v#f -> http://org.com/path?&prm=tgt_v&other_p=other_v#f', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=5&other_p&other_v#f'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=10&other_p&other_v#f'
           var uriActual = uri.setUriParam("bid",10)
           assert.equal(uriActual, uriExpected);
        });

        // remove the param-name , param-value pair
        it('http://org.com/path?prm=src_v&other_p=other_v#f -> http://org.com/path?&prm=tgt_v&other_p=other_v#f', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?bid=5&other_p=other_v#f'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&other_p=other_v#f'
           var uriActual = uri.setUriParam("bid",null)
           assert.equal(uriActual, uriExpected);
        });

        // remove the param-name , param-value pair
        it('http://org.com/path?&prm=src_v&other_p=other_v#f -> http://org.com/path?&prm=tgt_v&other_p=other_v#f', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?&bid=5&other_p=other_v#f'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&other_p=other_v#f'
           var uriActual = uri.setUriParam("bid",null)
           assert.equal(uriActual, uriExpected);
        });

        // add a new param name , param value pair
        it('http://org.com/path?prm=src_v&other_p=other_v#f -> http://org.com/path?&prm=tgt_v&other_p=other_v#f', function (){
           var uri = 'http://site.eu:80/qto/view/devops_guide_doc?&other_p=other_v#f'
           var uriExpected = 'http://site.eu:80/qto/view/devops_guide_doc?&other_p=other_v&bid=foo-bar#f'
           var uriActual = uri.setUriParam("bid","foo-bar")
           assert.equal(uriActual, uriExpected);
        });

     });
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.