JavaScript 函数默认参数值

标签 javascript jquery function parameters

我正在尝试为函数参数设置默认值,这将向我的服务器查询初始值。

最终目标是我将能够单击我创建的列表项之一来检索并创建新列表。

<script type="text/javascript">
        $(function getJobs(jobid=0) {
            {#jobid = 0;#}
            console.log("jobid: " + jobid);
            let query = {id: jobid};
            console.log(query);
            $.getJSON("{% url 'website:get-jobs' %}", query, function (data) {
                console.log("getjson");
                $.each(data, function (key, value) {
                    console.log(key + " - " + value);
                    $('#jobs-list').append("<li id='" + key + "'" + "href='#'" + "onclick=getJobs(key)" + ">" + value + "</li>");
                });
            });

        })
</script>

如果我手动将 jobid 设置为 0(在上面的代码中注释掉),一切都会正常工作。如果我尝试在函数参数列表中设置它,我会在 console.log 中看到以下内容: jobid: function(e,t){return new w.fn.init(e,t)}

最佳答案

当 jQuery 调用 $(function(x) { ... }) 的回调时,参数是 jQuery 对象本身,因此永远不需要默认值

所以,你会想要这样做

$(function() {
    function getJobs(jobid = 0) {
        console.log("jobid: " + jobid);
        let query = {id: jobid};
        console.log(query);
        $.getJSON("{% url 'website:get-jobs' %}", query, function (data) {
            console.log("getjson");
            $.each(data, function (key, value) {
                console.log(key + " - " + value);
                $('#jobs-list').append("<li id='" + key + "'" + "href='#'" + "onclick=getJobs(key)" + ">" + value + "</li>");
            });
        });
    }
    getJobs();
});

或者,使用原始代码,您当然可以测试 typeof jobid 是函数的情况,并将其设置为 0相反...即

$(function getJobs(jobid) {
    if (typeof jobid === 'function') {
        jobid = 0;
    }
    console.log("jobid: " + jobid);
    let query = {id: jobid};
    console.log(query);
    $.getJSON("{% url 'website:get-jobs' %}", query, function (data) {
        console.log("getjson");
        $.each(data, function (key, value) {
            console.log(key + " - " + value);
            $('#jobs-list').append("<li id='" + key + "'" + "href='#'" + "onclick=getJobs(key)" + ">" + value + "</li>");
        });
    });
});

关于JavaScript 函数默认参数值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55566079/

相关文章:

javascript - 如果没有从选择框中选择任何值(标题除外),则返回 false

c - 我如何告诉 C 程序创建 n 个数组,通过 scanf 读取 n?

javascript - JS如何对待函数参数?

javascript - fullCalendar Jquery 插件未出现在页面上

javascript - 如何检查 Controller 内元素的高度?

jquery - 如何使工具提示(qtip2)位于顶部中心?以及如何在其中添加图像?

function - 如何找到所有用户定义的(非扩展相关的)函数?

javascript - 单击时如何更改文本颜色

javascript - 这段 JavaScript 中没有任何反应

javascript - 将 jQuery 代码转换为 Mootools