this.$initialize 不是函数
this.$initialize is not a function
我最近开始使用Bridge.NET,我运行陷入了一个问题。
class定义如下
public class DomEngine
{
public DomEngine()
{
// Empty constructor to make sure it works
}
/* Lots of irrelevant code removed */
}
还有一个像这样的index.html
<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title>MenuGeneratorFromDom</title>
<script src="bridge.js"></script>
<script src="bridge.console.js"></script>
<script src="bridge.meta.js"></script>
<script src="jquery-2.2.4.js"></script>
<script src="MenuGeneratorFromDom.js"></script>
<script src="MenuGeneratorFromDom.meta.js"></script>
</head>
<body>
<h1>1.0</h1>
<h4>4.0</h4>
<h2>2.0</h2>
<h3>3.0</h3>
<h4>4.1</h4>
<h3>3.1</h3>
<h3>3.2</h3>
<h2>2.1</h2>
<h3>3.3</h3>
<h3>3.4</h3>
<h4>4.2</h4>
<h4>4.3</h4>
<script>
$(function()
{
var domEngine = MenuGeneratorFromDom.DomEngine();
});
</script>
</body>
</html>
我在 Bridge.NET
生成的代码中得到一个 this.$initialize is not a function
Bridge.define("MenuGeneratorFromDom.DomEngine",
{
ctors:
{
ctor: function ()
{
this.$initialize(); // Here
}
},
/* lots of generated code */
}
虽然 Initializ()
实际上是在 bridge.js
中用行
定义的
prop.$initialize = Bridge.Class._initialize;
(其中也定义了 Bridge.Class._initialize
),我们可以在上面的 index.html 中看到 bridge.js
包含在 MenuGeneratorFromDom.js
[=22= 之前的文件中]
我不明白为什么这个 Initialize
调用会抛出一个未定义的错误,而它显然是已定义的!我是不是忘记用 Bridge.NET 做点什么了?
尝试console.log(({}).toString.call(this.$initialize).match(/\s([a-zA-Z]+)/)[1].toLowerCase());
。
这应该输出this.$initialize的类型
如果未定义,则永远不会设置。如果它是其他东西,那么您可能需要查看该行,该函数被初始化并深入到右侧的值。
最后,我将我的存储库恢复到导致此错误的重构之前。我重新进行了重构,在每一步之间进行编译,并检查代码每次是否仍然有效。错误没有回来所以我真的不知道是什么原因造成的?
错误自行修复,所以感谢您的关注:-)
看来您只需要在调用中添加 new
关键字即可。您像静态方法一样调用 DomEngine()
,但它是一个构造函数。
// Fail
var domEngine = MenuGeneratorFromDom.DomEngine();
// Success!
var domEngine = new MenuGeneratorFromDom.DomEngine();
这是一个演示场景的简单 Deck:
https://deck.net/847bdcf3ee52dbc3297310507d5b15d3
希望对您有所帮助。
我最近开始使用Bridge.NET,我运行陷入了一个问题。
class定义如下
public class DomEngine
{
public DomEngine()
{
// Empty constructor to make sure it works
}
/* Lots of irrelevant code removed */
}
还有一个像这样的index.html
<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title>MenuGeneratorFromDom</title>
<script src="bridge.js"></script>
<script src="bridge.console.js"></script>
<script src="bridge.meta.js"></script>
<script src="jquery-2.2.4.js"></script>
<script src="MenuGeneratorFromDom.js"></script>
<script src="MenuGeneratorFromDom.meta.js"></script>
</head>
<body>
<h1>1.0</h1>
<h4>4.0</h4>
<h2>2.0</h2>
<h3>3.0</h3>
<h4>4.1</h4>
<h3>3.1</h3>
<h3>3.2</h3>
<h2>2.1</h2>
<h3>3.3</h3>
<h3>3.4</h3>
<h4>4.2</h4>
<h4>4.3</h4>
<script>
$(function()
{
var domEngine = MenuGeneratorFromDom.DomEngine();
});
</script>
</body>
</html>
我在 Bridge.NET
生成的代码中得到一个this.$initialize is not a function
Bridge.define("MenuGeneratorFromDom.DomEngine",
{
ctors:
{
ctor: function ()
{
this.$initialize(); // Here
}
},
/* lots of generated code */
}
虽然 Initializ()
实际上是在 bridge.js
中用行
prop.$initialize = Bridge.Class._initialize;
(其中也定义了 Bridge.Class._initialize
),我们可以在上面的 index.html 中看到 bridge.js
包含在 MenuGeneratorFromDom.js
[=22= 之前的文件中]
我不明白为什么这个 Initialize
调用会抛出一个未定义的错误,而它显然是已定义的!我是不是忘记用 Bridge.NET 做点什么了?
尝试console.log(({}).toString.call(this.$initialize).match(/\s([a-zA-Z]+)/)[1].toLowerCase());
。
这应该输出this.$initialize的类型
如果未定义,则永远不会设置。如果它是其他东西,那么您可能需要查看该行,该函数被初始化并深入到右侧的值。
最后,我将我的存储库恢复到导致此错误的重构之前。我重新进行了重构,在每一步之间进行编译,并检查代码每次是否仍然有效。错误没有回来所以我真的不知道是什么原因造成的?
错误自行修复,所以感谢您的关注:-)
看来您只需要在调用中添加 new
关键字即可。您像静态方法一样调用 DomEngine()
,但它是一个构造函数。
// Fail
var domEngine = MenuGeneratorFromDom.DomEngine();
// Success!
var domEngine = new MenuGeneratorFromDom.DomEngine();
这是一个演示场景的简单 Deck:
https://deck.net/847bdcf3ee52dbc3297310507d5b15d3
希望对您有所帮助。