使用 JavaScript 个 API 发布构建项目
Issue building project with JavaScript APIs
每当我使用 --release
选项为我的项目提供服务或构建它并在网页上 运行 时,我都会收到此错误控制台,并且某些功能将无法使用,使用 dartdevc
编译器,所有功能都可以正常工作。
例如,当我单击一个按钮时会发生这种情况:
jquery-3.3.1.slim.min.js:2 Uncaught TypeError: ((w.event.special[a.origType] || {}).handle || a.handler).apply is not a function
at HTMLDivElement.dispatch (jquery-3.3.1.slim.min.js:2)
at HTMLDivElement.v.handle (jquery-3.3.1.slim.min.js:2)
at Object.trigger (jquery-3.3.1.slim.min.js:2)
at HTMLDivElement.<anonymous> (jquery-3.3.1.slim.min.js:2)
at Function.each (jquery-3.3.1.slim.min.js:2)
at w.fn.init.each (jquery-3.3.1.slim.min.js:2)
at w.fn.init.trigger (jquery-3.3.1.slim.min.js:2)
at r.t.show (modal.js:117)
at HTMLDivElement.<anonymous> (modal.js:515)
at Function.each (jquery-3.3.1.slim.min.js:2)
dispatch @ jquery-3.3.1.slim.min.js:2
v.handle @ jquery-3.3.1.slim.min.js:2
trigger @ jquery-3.3.1.slim.min.js:2
(anonymous) @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
trigger @ jquery-3.3.1.slim.min.js:2
t.show @ modal.js:117
(anonymous) @ modal.js:515
each @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
r._jQueryInterface @ modal.js:498
cr @ index.dart.js:316
J.h4 @ index.dart.js:6202
dart.nN @ index.dart.js:6096
@ index.dart.js:4961
m6 @ index.dart.js:980
(anonymous) @ index.dart.js:989
这些是我从 Dart 调用的 js
API:
@JS()
library js_helper;
import 'package:js/js.dart';
@anonymous
@JS()
class SnackbarParams {
external factory SnackbarParams({String text, String pos, String backgroundColor});
external String get text;
external String get pos;
external String get backgroundColor;
}
@JS('Snackbar')
class Snackbar{
external static void show(SnackbarParams obj);
}
@JS('$')
external dynamic jQuery(query);
@JS()
@anonymous
class ModalElement {
external dynamic modal(String call);
external dynamic on(String event, Function callback);
}
@JS()
@anonymous
class jFormElement {
external dynamic serialize();
}
这应该是造成此错误的代码:
(jQuery('#loginModal') as ModalElement).modal('show');
最后,问题出在on
方法中,我需要将allowInterop
添加到Function
每当我使用 --release
选项为我的项目提供服务或构建它并在网页上 运行 时,我都会收到此错误控制台,并且某些功能将无法使用,使用 dartdevc
编译器,所有功能都可以正常工作。
例如,当我单击一个按钮时会发生这种情况:
jquery-3.3.1.slim.min.js:2 Uncaught TypeError: ((w.event.special[a.origType] || {}).handle || a.handler).apply is not a function
at HTMLDivElement.dispatch (jquery-3.3.1.slim.min.js:2)
at HTMLDivElement.v.handle (jquery-3.3.1.slim.min.js:2)
at Object.trigger (jquery-3.3.1.slim.min.js:2)
at HTMLDivElement.<anonymous> (jquery-3.3.1.slim.min.js:2)
at Function.each (jquery-3.3.1.slim.min.js:2)
at w.fn.init.each (jquery-3.3.1.slim.min.js:2)
at w.fn.init.trigger (jquery-3.3.1.slim.min.js:2)
at r.t.show (modal.js:117)
at HTMLDivElement.<anonymous> (modal.js:515)
at Function.each (jquery-3.3.1.slim.min.js:2)
dispatch @ jquery-3.3.1.slim.min.js:2
v.handle @ jquery-3.3.1.slim.min.js:2
trigger @ jquery-3.3.1.slim.min.js:2
(anonymous) @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
trigger @ jquery-3.3.1.slim.min.js:2
t.show @ modal.js:117
(anonymous) @ modal.js:515
each @ jquery-3.3.1.slim.min.js:2
each @ jquery-3.3.1.slim.min.js:2
r._jQueryInterface @ modal.js:498
cr @ index.dart.js:316
J.h4 @ index.dart.js:6202
dart.nN @ index.dart.js:6096
@ index.dart.js:4961
m6 @ index.dart.js:980
(anonymous) @ index.dart.js:989
这些是我从 Dart 调用的 js
API:
@JS()
library js_helper;
import 'package:js/js.dart';
@anonymous
@JS()
class SnackbarParams {
external factory SnackbarParams({String text, String pos, String backgroundColor});
external String get text;
external String get pos;
external String get backgroundColor;
}
@JS('Snackbar')
class Snackbar{
external static void show(SnackbarParams obj);
}
@JS('$')
external dynamic jQuery(query);
@JS()
@anonymous
class ModalElement {
external dynamic modal(String call);
external dynamic on(String event, Function callback);
}
@JS()
@anonymous
class jFormElement {
external dynamic serialize();
}
这应该是造成此错误的代码:
(jQuery('#loginModal') as ModalElement).modal('show');
最后,问题出在on
方法中,我需要将allowInterop
添加到Function