在Python和Javascript之间传递变量

时间:2011-10-07 15:49:39

标签: javascript python variables sqlalchemy

想象一下,当下拉列表发生变化时,您需要编写一些只更改一组复选框的Javascript。

根据列表中选择的项目,某些复选框将被选中/取消选中。

在后面,你有Python代码和一些SQLAlchemy。

Javascript需要像往常一样识别列表中的选定项目,将其发送回Python模块,然后Python模块将使用某些SQLAlchemy中的变量返回需要检查的复选框列表,即“用户选择”福特',所以复选框'焦点','蒙迪欧','嘉年华'需要检查“

我遇到的问题是,我似乎找不到从Javascript访问python模块的方法,而无需将div转换为迷你浏览器页面并将包含变量的URL传递给它!

有没有人对如何运作有任何想法?

2 个答案:

答案 0 :(得分:10)

好笑,我的网页上有JavaScript,与使用SQLAlchemy的Python CGI模块交谈。

我所做的是发送AJAX请求,但在正文中使用JSON请求而不是XML。 Python CGI模块使用标准json模块将JSON反序列化为字典。

JavaScript端看起来像这样:

function on_request_success(response) {
    console.debug('response', response);
} 

function on_request_error(r, text_status, error_thrown) {
    console.debug('error', text_status + ", " + error_thrown + ":\n" + r.responseText);
}

var request = { ... };
jQuery.ajax({
    url: 'http://host/whatever.cgi',
    type: 'POST',
    cache: false,
    data: JSON.stringify(request),
    contentType: 'application/json',
    processData: false,
    success: on_request_success,
    error: on_request_error
});

像这样的Python:

request = json.load(sys.stdin)
response = handle_request(request)
print("Content-Type: application/json", end="\n\n")
json.dump(response, sys.stdout, indent=2)

注意,它不使用Python cgi模块,因为整个请求在身体中作为JSON传递。

答案 1 :(得分:4)

python有一个json模块,非常适合这种情况。

使用一个好的旧AJAX,使用json作为数据格式将允许您在javascript和python模块之间交换数据。

(除非您的python模块在客户端运行,但我不知道如何从浏览器执行它...)