6

我是 Dart 新手,在开始使用 js-interop 库时遇到了麻烦。我想将 jquery ui 中的滑块添加到我的页面,但我无法弄清楚如何从 Dart 进行滑块()设置调用。js-interop 是正确的方法吗?对此的一些帮助将不胜感激。

void main() {
  js.scoped(() {
    var slider = query('#slider-range');
    var options = js.map({
      'range': true,
      'values': [ 17, 67 ]
    });
    // This doesn't work. Element has no method named slider.
    slider.slider(options);

    // In javascript it's done like this:
    // $( "#slider-range" ).slider({
    //   range: true,
    //   values: [ 17, 67 ]
    // });

    // This alert works.
    js.context.alert('Hello from Dart via JS');
  });
}
4

2 回答 2

3

在您的情况下,您必须使用js.context.$('#slider-range')而不是query('#slider-range')。基本上,js.context允许访问任何 Javascript 变量。通过使用js.context.$您可以访问 dart 端的jQuery javascript 对象(即$)。

import 'dart:html';
import 'package:js/js.dart' as js;

void main() {
  js.scoped(() {
    var slider = js.context.$('#slider-range');
    var options = js.map({
      'range': true,
      'values': [ 17, 67 ]
    });
    slider.slider(options);
  });
}
于 2012-11-02T14:28:30.983 回答
1

另一个示例代码:

import 'package:js/js.dart' as js;

js.context.jQuery();
var context = js.context;  
var param = js.map({ 'modal': true, "width":1000, "height":600});
js.context.jQuery("#dialog").dialog(param); 

在 HTML 中

<script src="packages/browser/interop.js"></script>

上面的代码使用 jQuery 打开一个 div 作为对话框。

于 2013-06-22T10:07:27.660 回答