0

我正在尝试使用 Transcrypt 的 fetch API。

资源:

headers = {
    "Access-Control-Request-Method": "GET",
    "Access-Control-Request-Headers": "origin, x-requested-with",
    "Origin": "https://bar.com/"
}

args = {
    "method":"OPTIONS",
    "headers":headers
}

fetch("https://foo.com/",args).then(
    lambda response: print(response),
    lambda err: print(err)
)

编译为:

var headers = dict ({'Access-Control-Request-Method': 'GET', 'Access-Control-Request-Headers': 'origin, x-requested-with', 'Origin': 'https://bar.com/'});
        var args = dict ({'method': 'OPTIONS', 'headers': headers});
        fetch ('https://foo.com/', args).then ((function __lambda__ (response) {
            return print (response);
        }), (function __lambda__ (err) {
            return print (err);
        }));

印刷:

TypeError: Failed to execute 'fetch' on 'Window': Iterator is not an object.

如果我dict从编译的代码中删除 s,它就会运行。

如何编译为正确的 Javascript 对象而不是 dict?

4

1 回答 1

2

现在明白了。

事实证明:

https://www.transcrypt.org/docs/html/special_facilities.html#create-bare-javascript-objects-and-iterate-over-their-attributes-from-python-pragma-jsiter-and-pragma-nojsiter

通常,Python {...} 文字被编译为 dict ({...}) 以包含 Python dict 的特殊属性和方法,例如迭代器。当pragma ('jsiter') 处于活动状态时,Python {...} 文字被编译为裸 {...},没有特殊属性或方法。为了仍然能够从 Python 迭代这样一个裸 JavaScript 对象的属性,当pragma ('jsiter') 处于活动状态时,Python for ... in ... 被字面翻译为 JavaScript for (var ...在 ...)。这个 pragma 的主要用例是方便地循环通过元类的方法中的类属性。作为一种更灵活但不太方便的替代方法,pragma ('js', '{}', '''...''

所以代码应该是:

__pragma__('jsiter')

headers = {
    "Access-Control-Request-Method": "GET",
    "Access-Control-Request-Headers": "origin, x-requested-with",
    "Origin": "https://bar.com/"
}

args = {
    "method":"OPTIONS",
    "headers":headers
}

__pragma__('nojsiter')
于 2018-05-19T16:34:48.833 回答