我可以使用Dart代码中的@observable声明使String或num类型可观察:
@observable
var x = '';
Run Code Online (Sandbox Code Playgroud)
和{{ }}html中的语法:
<div>x = {{x}}</div>
Run Code Online (Sandbox Code Playgroud)
但@observable不适用于列表和地图.我如何制作那些可观察的?
我是使用Dart的新手.我很想知道如何基于事件创建弹出窗口?我知道如何创建事件但不知道如何创建弹出窗口.
void main()
{
List<Element> radioButtons = queryAll(".requestType");
Iterator i = radioButtons.iterator();
while(i.hasNext)
{
var item = i.next();
item.on.click.add(addRequestTypeEvent);
}
}
void addRequestTypeEvent(Event event) {
<POPUP WINDOW>
}
Run Code Online (Sandbox Code Playgroud)
2013年1月17日更新:我想出了如何做到这一点.
window.open("http://www.yahoo.com", "yahoo", "status = 1, height = 300, width = 300, resizable = 0");
Run Code Online (Sandbox Code Playgroud) 我对 Dart 很陌生,我习惯于使用 C#(通常还有 XNA),所以 Dart 有点不同,我不确定为什么会发生这个错误。
double left = c.Position.x - (canvasDimensions.x * 0.5);
Run Code Online (Sandbox Code Playgroud)
Position 和 canvasDimensions 是我创建的一种类型,称为 Vector2,它基本上包含 2 个数字,x 和 y,我收到错误
NoSuchMethodError : method not found: '-'
Receiver: null
Arguments: [600.0]
Run Code Online (Sandbox Code Playgroud)
在显示的行中,由于我不熟悉该语言,我不确定为什么会发生这种情况,请帮助,谢谢!
我无法弄清楚如何使用@observable annotation/Observable类在对象状态发生变化时获取简单通知.
import 'package:web_ui/observe.dart';
@observable class T{
String x;
// what else is needed?
}
T t = new T();
observe(t, (e) => print ("Value changed"));
t.x = "Changed";
Run Code Online (Sandbox Code Playgroud)
如果可能的话,我想使用没有web-ui其余部分的observable(作为backbone.js的替代品).
以下代码抛出异常 "type '([int]) => void' is not a subtype of type 'RequestAnimationFrameCallback' of 'callback'."
import 'dart:html';
void main() {
window.animationFrame.then((time) => print("test"));
}
Run Code Online (Sandbox Code Playgroud)
如果我更改window.animationFrame.then为window.requestAnimationFrame,一切都会按预期进行。我是否误解了 Dart 期货的运作方式?
使用Web UI时,我可以将数据传递给这样的组件:
<my-element" name="{{someName}}"></my-element>
Run Code Online (Sandbox Code Playgroud)
如何将数据传递给Polymer元素?
我可以使单选按钮工作并绑定到模型.但是,当页面加载时,即使有一个单选按钮,也没有显示选中的单选按钮.
这是Dart代码:
import 'package:angular/angular.dart';
@NgDirective(
selector: '[my-controller]',
publishAs: 'ctrl'
)
class MyController {
List<String> fruits = ['apple', 'banana', 'kiwi'];
String favorite;
MyController() {
favorite = fruits[1];
}
}
main() {
ngBootstrap(module: new Module()..type(MyController));
}
Run Code Online (Sandbox Code Playgroud)
这是视图标记.一旦我开始选择无线电,UI就会正确更新,数据绑定也能正常工作.但是在页面加载时没有选择任何内容.不知道为什么会这样.
<!DOCTYPE html>
<html ng-app>
<body>
<div my-controller>
<div ng-repeat="fruit in ctrl.fruits">
<input type="radio"
name="fruits"
ng-model="ctrl.favorite"
value="{{fruit}}">{{fruit}}
</div>
<div>{{ctrl.favorite}} is my favorite</div>
</div>
<script type="application/dart" src="main.dart"></script>
<script type="text/javascript" src="packages/browser/dart.js"></script>
</body>
</html>
Run Code Online (Sandbox Code Playgroud) 角JS有$pristine,$dirty,$valid,和$invalid用于检查表单的状态布尔值.Angular Dart中有相应的等价物吗?
因此,例如,鉴于我有以下课程
class Foo{
String id;
Foo(this.id);
}
Run Code Online (Sandbox Code Playgroud)
我想要某种 Foos 集合,然后能够通过其 id 找到任何 Foo。我想比较这两种实现方式:
带地图:
var foosMap = <String, Foo>{"foo1": new Foo("foo1"), "foo2": new Foo("foo2")};
var foo2 = foosMap["foo2"];
Run Code Online (Sandbox Code Playgroud)
使用列表:
var foosList = <Foo>[new Foo("foo1"), new Foo("foo2")];
var foo2 = foosList.singleWhere((i) => i.id == "foo2");
Run Code Online (Sandbox Code Playgroud)
第一种方式(使用地图)在性能方面是否更方便?还有其他需要考虑的因素吗?
ctrl+v当我按下页面时,我尝试使用gist中的代码从剪贴板获取图像,这将console.log获得它所获取的图像内容。
我发现图像内容是一个长的base64字符串,带有特殊的前缀:

Run Code Online (Sandbox Code Playgroud)
如何将其解码为二进制?我尝试删除前缀data:image/png;base64,并使用 base64 库将其余部分解码为二进制,并将其保存到文件中image.png。但文件无法显示,出现invalid format错误。
但是如果我将整个字符串粘贴到http://base64online.org/decode/,它也可以播放图像。
我使用的base64库是https://github.com/wstrange/base64,我的代码是:

Run Code Online (Sandbox Code Playgroud)
我不知道哪里错了:(
dart ×10
angular-dart ×2
angularjs ×2
dart-webui ×2
base64 ×1
dart-html ×1
image ×1
png ×1
polymer ×1