我使用其在反映GUI結構的方式來構造模型類和我將它們綁定到所述聚合物元件等如下所示。 與控制器類似,但這會對SO回答產生不同程度的影響。
我沒有測試這個代碼 - 這只是爲了演示這個想法。
import 'package:polymer/polymer.dart';
class AppModel {
var loginModel = new LoginModel();
var moviesModel = new MoviesModel();
var actorsModel = new ActorsModel();
}
class LoginModel extends Observable {
@observable bool isAuthenticated;
@observable String userName;
@observable String email;
}
class MoviesModel {
final List<MovieModel> movies = toObservable(<MovieModel>[]);
}
class MovieModel extends Observable {
@observable String id;
@observable String name;
@observable int rating;
final List<ActorModel> actors = toObservable(<ActorModel>[]);
}
class ActorsModel {
final List<ActorModel> actors = toObservable(<ActorModel>[]);
}
class ActorModel extends Observable {
@observable String id;
@observable String firstName;
@observable String middleName;
@observable String lastName;
@observable DateTime birthDate;
final List<MovieModel> movies = toObservable(<MovieModel>[]);
}
。
<polymer-element name="login-dropdown">
<template>
<template if="model.isAuthenticated">
<label for="userName"><input id="userName" value="{{model.userName}}" disabled></label>
<label for="email"><input id="email" value="{{model.email}}" disabled></label>
<button on-click="{{handleSignOut}}">Sign out</button>
</template>
<template if="!model.isAuthenticated">
<label for="userName"><input id="userName" value="{{model.userName}}"></label>
<button on-click="{{handleSignIn}}">Sign out</button>
</template>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('login-dropdown')
class LoginDropdown extends PolymerElement {
LoginDropdown.created() : super.created();
@PublishedProperty(reflect: true) MoviesModel model;
}
</script>
</polymer-element>
<polymer-element name="app-element">
<template>
<header-toolbar>
<login-dropdown-button>
<login-dropdown model="{{model.loginModel}}"></login-dropdown>
</login-dropdown-button>
</header-toolbar>
<tab-control>
<tab-panel label="Movies">
<movies-panel model="{{model.moviesModel}}"></movies-panel>
</tab-panel>
<tab-panel label="Actors">
<actors-panel model="{{model.actorsModel}}"></actors-panel>
</tab-panel>
</tab-control>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('app-element')
class AppElement extends PolymerElement {
AppElement.created() : super.created();
AppModel model = new AppModel();
}
</script>
</polymer-element>
<polymer-element name="movies-panel">
<template>
<template repeat="{{movie in model.movies}}">
<movie-panel model="{{movie}}"></movie-panel>
</template>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('movies-panel')
class MoviesPanel extends PolymerElement {
MoviesPanel.created() : super.created();
@PublishedProperty(reflect: true) MoviesModel model;
}
</script>
</polymer-element>
<polymer-element name="movie-panel">
<template>
<div data-id="{{model.id}}">
<div><span>Name:</span><span>{{model.name}}</span></div>
<div><span>Rating:</span><span>{{model.rating}}</span></div>
</div>
<template repeat="{{actor in model.actors}}">
<actor-panel model="{{actor}}"></actor-panel>
</template>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('movies-panel')
class MoviesPanel extends PolymerElement {
MoviesPanel.created() : super.created();
@PublishedProperty(reflect: true) MoviesModel model;
}
</script>
</polymer-element>
<polymer-element name="actors-panel">
<template>
<template repeat="{{actor in model.actors}}">
<actor-panel model="{{actor}}"></actor-panel>
</template>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('actors-panel')
class ActorsPanel extends PolymerElement {
ActorsPanel.created() : super.created();
@PublishedProperty(reflect: true) ActorsModel model;
}
</script>
</polymer-element>
<polymer-element name="actor-panel">
<template>
<div data-id="{{model.id}}">
<div><span>First name:</span><span>{{model.firstName}}</span></div>
<div><span>Middle name:</span><span>{{model.middleName}}</span></div>
<div><span>Last name:</span><span>{{model.lastName}}</span></div>
<div><span>Date of birth:</span><span>{{model.birthDate}}</span></div>
</div>
<template repeat="{{movie in model.movies}}">
<movie-panel model="{{movie}}"></movie-panel>
</template>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'model.dart';
@CustomTag('actor-panel')
class ActorPanel extends PolymerElement {
ActorPanel.created() : super.created();
@PublishedProperty(reflect: true) ActorModel model;
}
</script>
</polymer-element>
另請參閱Use a class as attribute for a dart polymer element更多有趣的選項。
看看它的另一種可能的方法是子聚合物元素生成消息,這些消息會起泡並被父元素捕獲,並處理數據。所以子元素不需要訪問整個應用程序,只是爲了生成並拋出其他東西稍後會捕獲的消息。 http://www.polymer-project.org/articles/communication.html –
處理業務邏輯的最佳位置是服務器端代碼。 – mezoni