- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在通过 JSNI 使用测试数据来利用名为 cytoscape.js 的外部 JavaScript 库。当我在 java 类中通过 JSNI 运行脚本时,它无法生成图表。但是,当我通过 Chrome Devtools 控制台运行它时,它可以正常工作。
所有值似乎都正确传递到 cytoscape.js 库。目前,JSNI 代码未通过控制台代码能够通过的 Javascript 库执行的测试。
这是我正在使用的 JSNI 代码:
public static native void cytoscape() /*-{
var cy = $wnd.cy = $wnd.cytoscape({container: $wnd.document.getElementById('cy'),
elements: $wnd.glyElements,
style: [ { selector: 'node', style: { 'background-color': '#666', 'label': 'data(id)' } },
{ selector: 'edge', style: { 'width': 3, 'line-color': '#ccc', 'target-arrow-color': '#ccc', 'target-arrow-shape': 'triangle' } } ],
layout: { name: 'grid', rows: 1 } });
}-*/;
“$wnd”。用于获取正确的范围。
这是控制台代码:
var cy = window.cy = cytoscape({
container: document.getElementById('cy'),
elements: glyElements,
style: [ { selector: 'node', style: { 'background-color': '#666', 'label': 'data(id)' } }, { selector: 'edge', style: { 'width': 3, 'line-color': '#ccc', 'target-arrow-color': '#ccc', 'target-arrow-shape': 'triangle' } } ],
layout: { name: 'grid', rows: 1 }
});
我在这两种情况下使用的元素都存储在 .js 文件中,并且我确保它们在这两种情况下都可以访问。就像我提到的,Devtools 调试显示正确的值已传递到 cytoscape.js 库中。
JSNI 代码在 cytoscape.js 库中的返回语句失败:
var plainObject = function plainObject(obj) {
return obj != null && _typeof(obj) === typeofobj && !array(obj) && obj.constructor === Object;
};
如果我注释掉“&& obj.constructor === Object;”在 cytoscape.js 的第 145 行,代码与我的 JSNI 脚本一起正确运行。这让我相信 cytoscape 对象是通过 JSNI 创建的,与通过控制台创建的不同。尽管如此,开发工具仍将控制台和 JSNI 方法列为提供相同的对象。如何更新我的 JSNI 代码以使其符合此检查?
理想情况下,JSNI 在这种情况下应该可用。我不确定为什么通过 JSNI 传递值会导致该 if 语句在通过控制台传递 if 语句运行时失败。
最佳答案
问题是 Object 与 Object 并不完全相同,检查 instanceof
几乎肯定比 cytoscape 的作者认为的要多得多 - JS 不是很伟大吗?
cytoscape.js
项目的 instanceof Object
测试不仅仅是测试“这个东西是普通对象还是其他类型的实例”,而是实际上测试“这是我的窗口实例中的 Object 类的实例,而不是来自任何其他 iframe/窗口”。
GWT 的默认链接器会在 iframe 中评估您的代码,以防止意外泄漏全局变量和混淆加载到同一页面的 JS,或者让同一页面上的其他 JS 覆盖或以其他方式弄乱 GWT 的代码。
除了尝试将 cytoscape 的代码纠正为不那么严格和不灵活之外,还有几种方法可以解决此问题。
{...}
语法,该语法默认为您碰巧所在的任何窗口执行中。像这样: public static native void cytoscape() /*-{
var obj = new $wnd.Object();
obj.container = $wnd.document.getElementById('cy');//can also be simply $doc.getElementById('cy')
obj.elements = $wnd.glyElements;
// Note that you may have to repeat this for each of these nested objects, depending
// on how picky the library is being on otherwise identically structured code...
obj.style = [ { selector: 'node', style: { 'background-color': '#666', 'label': 'data(id)' } },
{ selector: 'edge', style: { 'width': 3, 'line-color': '#ccc', 'target-arrow-color': '#ccc',
'target-arrow-shape': 'triangle' } } ];
obj.layout = { name: 'grid', rows: 1 };
var cy = $wnd.cy = $wnd.cytoscape(obj);
}-*/;
关于javascript - JSNI 脚本失败,但在 Chrome Devtools 控制台中运行时脚本成功,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57331705/
使用 GWT JSNI JavaScriptObject 和 Element 作为 JSNI 方法的参数类型有什么区别? 考虑以下方法: native void method(JavaScriptOb
是否可以通过这种方式从同一个类中的另一个 native 方法调用 native 方法? public native JavaScriptObject mySECONDJsniMethod(String
我想在我的 gwt 应用程序中调用外部 javascript 函数 当我使用此代码时,它工作正常:我已经导入了javaScript,我可以在客户端的firebug中看到它 public static
我正在尝试在我的 GWT 项目中提供一些函数 Hook : private TextBox hello = new TextBox(); private void helloMethod(String
下面是访问 JS 方法的常用方法: public class JSNIHelper { public static native void errorNotify(String _title,
我有一个文件 jQuery 来创建翻转卡片效果,我将其更改为 JSNI,使用 native 函数但错误。我不知道怎么了。有谁能够帮我? 这是我的 native 功能: public native vo
我正在尝试在我的项目中实现 pickdate.js : http://amsul.ca/pickadate.js/date.htm 当我尝试调用该方法时: private native void ex
我正在尝试将此 JavaScript 代码转换为 JSNI 代码。 脚本导入 脚本 $('#q').typeahead({ minLength: 1, order: "as
我正在构建一个使用 Web SQL 本地存储的 GWT 应用程序 ( http://dev.w3.org/html5/webdatabase/ )。问题是 Web SQL API 使用回调函数作为论据
所以我有一个 GWT 应用程序,我正在尝试调用一个函数来从外部按钮更改应用程序的 View 。通常这被称为“this.internalFunction('string')”。问题是 JSNI 通过静态
我在 GWT 类中有以下代码: private native JavaScriptObject getRequest() /*-{ var request = ...; request
这是我的代码: package com.eggproject_hu.WPECommerceAdminSales.client; import java.lang.Boolean; import com
这是我的代码: package com.eggproject_hu.WPECommerceAdminSales.client; import java.lang.Boolean; import com
我正在开发一个 GWT 应用程序,并且正在获取一个包含选择查询结果的列表。此选择查询有行。每行的每个元素都通过“::”与前一个和下一个元素分隔。 我尝试使用 String.split 拆分它,但需要很
我想为以下 JavaScript 函数编写一个 GWT JSNI 包装函数。 object.cache(config); 其中 config 是具有以下可选参数的对象 - x Number - y N
我想在我的 gwt 代码中创建一个 canvas 元素。随后,我想应用第三方 javascript 库以便在新创建的 canvas dom 元素上进行绘制。所以这是我想做的事情的粗略想法: publi
我正在更改 JSNI 中的 JavaScript 函数,但事件监听器未正确调用。这是代码: private native void alert1()/*-{ $doc.addEventList
考虑以下小部件。我将其中两个添加到我的页面中。第一个的名称为“widget1”,第二个的名称为“widget2”。它只应该给出自己的名称,但由 javascript 调用。 (这个例子没有任何意义,只
我想从 gwt 调用任意 js 函数。函数名将在 functionname 变量中。像这样: private static native String execute(String functionN
html中有一个JavaScript函数 function someFunction(){ return "some text"; } 还有 JSNI: native String
我是一名优秀的程序员,十分优秀!