javascript - Brython:从单独的 python 文件调用对象的方法

标签 javascript python brython

我对 Brython 框架很陌生,所以我的问题将是一个基本问题。对此深表歉意。

这是我的脚本“log.py”:

import math

class Logarithm:
    def__init__(self,x,y):
        self.x = x
        self.y = y

    def log(x,y):
        return math.log(x[,y])

在 html 中:

        <script src = "https://cdnjs.cloudflare.com/ajax/libs/brython/3.3.20/brython_stdlib.js"></script>

        <script src = "log.py" type = "text/python"></script>
        <script>
             //some javascript code
        </script>

现在,在我的 javascript 中,我想调用 Logarithm 类的 log() 函数。谁能告诉我如何才能做到这一点?

提前致谢:-)

最佳答案

Brython 允许您直接在浏览器中编写 Python - 但这意味着您必须知道您在 Python 端做什么。您的代码段在语法上是不正确的 Python。当我们修复语法时,我们必须修复它以使其有意义 - (因此,如果您在类构造时将 x 和 y 作为对数操作数和底数,则在使用日志时您不希望再次使用).

然后,当我们修复它时,您必须修复 html 部分,以便它可以正确使用 Brython。然后你就可以随心所欲了。始终查看 Javascript 控制台输出 (ctrl + F12) - Brython 可以生成一些有用的回溯,一旦它被加载,就会告诉 Python 代码上的错误。

然后你必须记住,尽管 Brython 的作者已经使从普通 Javascript 调用 Python 函数变得几乎透明,但使用下面的规定,对于类和方法来说,这并不能以这种直接透明的方式工作——你尝试使用。

TL;DR:对于已经有一些 Brython 代码可以工作并想从 Javascript 调用 Brython 函数的人,只需在 Brython 代码上做:

def my_func(...):
    ...

from browser import window
window.my_func = my_func

您现在可以从纯 Javascrit 脚本 block 中使用“my_func”,但是您必须允许 Brython 加载和运行它的代码的时间——任何使用 Brython 的 javascript 都必须在 onload 事件运行主 brython 函数。请参阅下面的示例。

因此,对于您的情况,我们可以将 log.py 文件重写为:

import math

class Logarithm:
    def __init__(self, x, y=10):
        self.x = x
        self.y = y

    def log(self):
        return math.log(self.x,self.y)


from browser import window
window.Logarithm = Logarithm

然后,我们必须正确编写 html 文件来加载主 Brython Python stdlib 作为两个单独的脚本标记,在 onload 事件上激活 brython,然后我们就可以开始了:

<html>
  <head>
    <script src="http://brython.info/src/brython.js"></script>
    <script type="text/javascript" src="http://brython.info/src/brython_stdlib.js"></script>
    <script src="log.py" type="text/python3"></script>
    <script type="text/javascript">
        function do_python() {
            var obj = window.Logarithm(100, 10);
            var result = obj.__class__.log(obj);
            document.write(result);
        }
    </script>
  </head>
  <body onload="brython(); setTimeout(do_python, 300)">

  </body>
</html>

请注意,实际调用 Brython 类的 Javascript 包含在 setTimeout 调用中。这允许 Brython 进行设置。 虽然您可以通过简单地调用类来创建 Brython 对象的实例,但要调用它的方法,您必须手动调用 __class__ 属性,并将该实例作为第一个参数显式传递。

在类中查找方法名并自动添加self参数的机制仅在从Brython使用实例时使用。

关于javascript - Brython:从单独的 python 文件调用对象的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47396494/

相关文章:

javascript - 如何在羽毛中分离中间件?

javascript - 为什么所选的 <option> css 查询为 :checked, 但 HTML 和 Javascript 正在使用所选内容?

python - 使用 xlwt 与 openpyxl

python - matplotlib 中的高质量绘图

python - 从顺序 Keras 模型中保存特定层

javascript - 如何将文本输入绑定(bind)到同一 html 页面上的另一个 div

javascript - python markdown哪个版本有mark方法

javascript - 使用 jquery 将行值设为另一个文本

javascript - 如何将本地日期转换为UTC格式?

javascript - Brython 将点击事件绑定(bind)到页面中尚未存在的 id