app/gwt/dashboard/src/dashboard/client/Dashboard.java//import類は省くが困ったらgwtのモノを選んどけばたいてい大丈夫
public class Dashboard implements EntryPoint {
public void onModuleLoad() {
final Button button = new Button("Click me");
final Label label = new Label();
button.addClickListener(new ClickListener() {
public void onClick(Widget sender) {
//add
ResourceCollection projects = new RailsJsonResourceCollection(
"/projects/", new ResourceFactory() {
public Resource create() {
return (Resource) GWT.create(Project.class);
}
});
projects.find(1, new ResourceResponseHandler() {
public void onSuccess(Resource resource) {
Window.alert("Before: Project name is "
+ ((Project) resource).getName());
Project p = (Project) resource;
p.setName("ABC");
ResourceCollection projects2 = new RailsJsonResourceCollection(
"/projects/", new ResourceFactory() {
public Resource create() {
return (Resource) GWT
.create(Project.class);
}
});
projects2.update(p, new StatusResponseHandler() {
public void onSuccess() {
Window.alert("SUCCESS");
ResourceCollection projects3 = new RailsJsonResourceCollection(
"/projects/", new ResourceFactory() {
public Resource create() {
return (Resource) GWT
.create(Project.class);
}
});
projects3.find(1, new ResourceResponseHandler() {
public void onSuccess(Resource resource) {
Window.alert("After: Project name is "
+ ((Project) resource).getName());
}
public void onError(Request request, Throwable exception) {
}
});
}
public void onError(Request request,
Throwable exception) {
Window.alert("ERROR");
}
});
}
public void onError(Request request, Throwable exception) {
}
});
//add
if (label.getText().equals(""))
label.setText("Hello World!");
else
label.setText("");
}
});
//slotは'app/views/dashboard/index.html.erb'内のidでの定義.
//button, labelはそこにハマる.
RootPanel.get("slot1").add(button);
RootPanel.get("slot2").add(label);
}
}
これはid=1のname属性を'ABC'へ更新する例.流れはまずid=1を取得しそのname属性をalertで表示する.次にname=ABCと置き換え,それを更新処理にまわす.再度id=1を取得しそのname属性をalertで表示する.
実際はupdateメソッドの第一引数となるオブジェクトのid値を更新対象とするためidを書き換えれば呼出した対象と異なる対象が更新される.例えばsetId(2)とすれば更新されるのは(JSON Requestは)id=2のデータである.
> rake dashbaord:compile
> script/server
ブラウザにて'http://localhost:3000/dashboard/'へアクセス
0 件のコメント:
コメントを投稿