nested-viewmodels.html 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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. <script src="../../../dist/seed.js"></script>
  21. </head>
  22. <body>
  23. <div id="grandpa" data-name="Andy" data-family="Johnson">
  24. <p class="ancestor">{{name}} {{family}}</p>
  25. <div sd-viewmodel="man" data-name="Jack">
  26. <p>{{name}}, son of {{^name}}</p>
  27. <div sd-viewmodel="man" data-name="Mike">
  28. <p>{{name}}, son of {{^name}}</p>
  29. <div sd-viewmodel="offspring" data-name="Tim">
  30. </div>
  31. <div sd-viewmodel="offspring" data-name="Tom">
  32. </div>
  33. </div>
  34. <div sd-viewmodel="man" data-name="Jason">
  35. <p>{{name}}, son of {{^name}}</p>
  36. <div sd-viewmodel="offspring" data-name="Andrew">
  37. </div>
  38. </div>
  39. </div>
  40. </div>
  41. <script type="text/sd-template" id="sd-template-offspring">
  42. <p>
  43. {{name}}, son of {{^name}},
  44. <br>
  45. grandson of {{^^name}},
  46. <br>
  47. great-grandson of {{$name}},
  48. <br>
  49. and offspring of family {{family}}.
  50. </p>
  51. </script>
  52. <script>
  53. Seed.config({ debug: true })
  54. var Man = Seed.extend({
  55. init: function () {
  56. this.name = this.$el.dataset.name
  57. var family = this.$el.dataset.family
  58. if (family) {
  59. this.family = family
  60. }
  61. }
  62. })
  63. var Offspring = Man.extend({
  64. template: document.getElementById('sd-template-offspring').innerHTML
  65. })
  66. Seed
  67. .viewmodel('man', Man)
  68. .viewmodel('offspring', Offspring)
  69. new Man({
  70. el: '#grandpa'
  71. })
  72. </script>
  73. </body>
  74. </html>