nested-viewmodels.html 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Nested Controllers</title>
  5. <style type="text/css">
  6. div:not(#grandpa) {
  7. padding-left: 15px;
  8. }
  9. p {
  10. position: relative;
  11. }
  12. p:not(.ancestor):before {
  13. position: absolute;
  14. top: 0;
  15. left: -22px;
  16. content: "└ ";
  17. color: #F00;
  18. }
  19. </style>
  20. </head>
  21. <body>
  22. <div id="grandpa" sd-viewmodel="man" data-name="Andy" data-family="Johnson">
  23. <p class="ancestor">{{name}} {{family}}</p>
  24. <div sd-viewmodel="man" data-name="Jack">
  25. <p>{{name}}, son of {{^name}}</p>
  26. <div sd-viewmodel="man" data-name="Mike">
  27. <p>{{name}}, son of {{^name}}</p>
  28. <div sd-viewmodel="man" data-name="Tim" sd-template="offspring">
  29. </div>
  30. <div sd-viewmodel="man" data-name="Tom" sd-template="offspring">
  31. </div>
  32. </div>
  33. <div sd-viewmodel="man" data-name="Jason">
  34. <p>{{name}}, son of {{^name}}</p>
  35. <div sd-viewmodel="man" data-name="Andrew" sd-template="offspring">
  36. </div>
  37. </div>
  38. </div>
  39. </div>
  40. <script type="text/sd-template" sd-template-id="offspring">
  41. <p>
  42. {{name}}, son of {{^name}},
  43. <br>
  44. grandson of {{^^name}},
  45. <br>
  46. great-grandson of {{$name}},
  47. <br>
  48. and offspring of family {{family}}.
  49. </p>
  50. </script>
  51. <script src="../dist/seed.js"></script>
  52. <script>
  53. seed.config({ debug: true })
  54. var Man = seed.ViewModel.extend({
  55. id: 'man',
  56. init: function () {
  57. this.name = this.$el.dataset.name
  58. var family = this.$el.dataset.family
  59. if (family) {
  60. this.family = family
  61. }
  62. }
  63. })
  64. seed.bootstrap('#grandpa')
  65. </script>
  66. </body>
  67. </html>