javascript - 将参数传递给函数 onclick jQuery

标签 javascript jquery url url-rewriting extract

我正在尝试使用 jquery 从 URL 中删除参数。实际上参数必须动态传递,并且应该是单击时父元素的文本。然后在添加前缀后,我需要将其传递给函数。

如下图所示,当有人点击清除链接时,它会从标题标题中获取过滤器名称,即COLOR,添加一些前缀后,例如js_,然后将此 js_color 传递给函数。

到目前为止,我已经做了类似的事情,但似乎不起作用。你能帮我一下吗?

谢谢

编辑:

如果我手动传递参数值,它工作正常。

工作:removeParam("js_color", url)

不工作:removeParam(param, url)

fiddle :https://jsfiddle.net/jz1dyh9r/

函数未获取第一个参数的值。

enter image description here

    // Append Clear Link to element
    $('.woof_redraw_zone .woof_container_inner h4').each(function(){
        $(this).append('<a class="clear_filters">Clear</a>');
    });

    // Extract parameter, pass it to function and generate new URL
    $('.woof_redraw_zone .woof_container_inner h4').click(function(){
        var url = window.location.href;
        var prefix = ("pa_");
        var key = $(this).clone().children().remove().end().text().toLowerCase();
        var param = prefix + key;
        var alteredURL = removeParam(param, url);
        console.log( removeParam(param, url) );
        // window.location.href = alteredURL;
    });

//引用:Remove a parameter to the URL with JavaScript

    function removeParam(key, sourceURL) {
        var rtn = sourceURL.split("?")[0],
            param,
            params_arr = [],
            queryString = (sourceURL.indexOf("?") !== -1) ? sourceURL.split("?")[1] : "";
        if (queryString !== "") {
            params_arr = queryString.split("&");
            for (var i = params_arr.length - 1; i >= 0; i -= 1) {
                param = params_arr[i].split("=")[0];
                if (param === key) {
                    params_arr.splice(i, 1);
                }
            }
            rtn = rtn + "?" + params_arr.join("&");
        }
        return rtn;
    }       

最佳答案

您的比较字符串可能包含空格和换行符,请在比较字符串之前使用 trim()

function removeParam(key, sourceURL) {
        var rtn = sourceURL.split("?")[0],
            param,
            params_arr = [],
            queryString = (sourceURL.indexOf("?") !== -1) ? sourceURL.split("?")[1] : "";
        if (queryString !== "") {
            params_arr = queryString.split("&");
            for (var i = params_arr.length - 1; i >= 0; i -= 1) {
                param = params_arr[i].split("=")[0];
                if (param.trim() === key.trim()) { // compare trimmed strings
                    params_arr.splice(i, 1);
                }
            }
            rtn = rtn + "?" + params_arr.join("&");
        }
        return rtn;
    }       

关于javascript - 将参数传递给函数 onclick jQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39739007/

相关文章:

javascript - 为什么事件处理程序能够劫持我对 eval 的直接调用?

javascript - 从 json 字符串中的 json 中提取值

javascript - 为什么 underscore.reduce 在这两种情况下表现不同?

javascript - 根据 URL 单击选项卡

jquery - 拖动调整大小 handle 时多次触发调整大小事件

JavaScript 的 URL 绝对路径在一个页面上有效,但在另一个页面上创建 ajax 错误消息

javascript - 无法使用react js获取表上的数据

javascript - 在不同宽度的可排序 div 中使用 amchart

python - 在 django 开发服务器上工作,但不在 apache 上工作

java - java url 和命名空间转换