jquery - .getJSON 传递同名变量数据

标签 jquery

我在 .getJSON 中传递数据时遇到问题。这样做的原因是因为我需要传递具有相同名称的变量。所以,我有一个 python 客户端,我用该代码执行此操作:

query_args = { 'name':[var1,var2,var3] }

output = urllib2.urlopen('http://'+servername+':'+port+'/'+action,urllib.urlencode(query_args,doseq=True))

如果我尝试在 javasctipt 中使用 .getJSON 来做到这一点,我会尝试这样做

$.getJSON(
    "http://servername::8001/SearchNode",
    {
        name: "name",
        name: "google"
    },
    function(data) {

        $.each(data, function(key, val) {
            console.log(key);
            console.log(val);
        });
    }   
);

当我调试查询字符串时,我只看到其中一个变量。谁能给我一个简单的解决方案来解决我的问题?

问候

最佳答案

要在一个变量中传递多个对象,您必须使用另一种结构。在您的情况下,您希望发送字符串 namegoogle。通过使用您的方法,您只需覆盖变量名称的值即可。

有多种方法可以解决这个问题。我必须说,我已经有一段时间没有使用Python了(所以phytoneers请随意纠正我)。

想法 1: 重命名 js 代码中的参数并在 python 中将它们粘合在一起。更改 2 个参数中的一个键,这样它们就不会覆盖...

$.getJSON(
    "http://servername::8001/SearchNode",
    {
        name1: "name", 
        name2: "google"
    },
    function(data) {...}
) 

...然后重建你的数组...

query_args = {'name': [name1, name2] }

或者或者不理会query_args,而是直接将它们处理到你的urllib.urlencode

output = urllib2.urlopen('yoururl', urllib.urlencode({'name':[name1, name2]}, True))

想法 2: 这可能就是您想要做的。将两个字符串放入一个数组中并将其作为参数发送。在json.org您可以查看通过 ajax 发送的不同类型的数据结构。 在这种情况下,您的代码将如下所示:

$.getJSON(
    "http://servername::8001/SearchNode",
    {
        name: ["name", "google"]
    },
    function(data) {...}
) 

使用此方法,您可以轻松添加更多参数,而无需添加稍后需要连接的许多不同变量。 由于我对 python 不太熟悉,所以我无法告诉你 python 将如何存储它(可能是一个列表)。但无论哪种方式,您都应该能够在 urlencode 函数中处理这个问题。 (至少documentation说,它必须是一个序列,这个列表肯定是)

关于jquery - .getJSON 传递同名变量数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9979769/

相关文章:

jquery autotab 不要制表符下一行

javascript - 为新的 div 添加独特的类

javascript - Bootstrap 导航栏折叠按钮不起作用

javascript - 图片淡入淡出($未定义)

jQuery - 在新窗口中打开 id 中的所有链接

javascript - 当将数据插入数组时仅插入一个索引

javascript - 是否可以使用一些自定义选项调用 $ ('form' ).validationEngine ('validate' )?

javascript - 附加的新行的行为与前一行(行)不同

javascript - for循环中的点击事件

javascript - 将类(悬停时)添加到目标池,但不添加到悬停元素