nested-viewmodels.html 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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/vue.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 v-component="man" data-name="Jack">
  26. <p class="jack">{{name}}, son of {{^name}}</p>
  27. <div v-component="man" data-name="Mike">
  28. <p class="mike">{{name}}, son of {{^name}}</p>
  29. <div v-component="offspring" data-name="Tim" class="tim">
  30. </div>
  31. <div v-component="offspring" data-name="Tom" class="tom">
  32. </div>
  33. </div>
  34. <div v-component="man" data-name="Jason">
  35. <p class="jason">{{name}}, son of {{^name}}</p>
  36. <div v-component="offspring" data-name="Andrew" class="andrew">
  37. </div>
  38. </div>
  39. </div>
  40. </div>
  41. <script type="text/v-template" id="v-template-offspring">
  42. <p>{{name}}, son of {{^name}}, grandson of {{^^name}}, great-grandson of {{*name}}, and offspring of family {{family}}.</p>
  43. </script>
  44. <script>
  45. Vue.config({ debug: true })
  46. var Man = Vue.extend({
  47. created: function () {
  48. this.name = this.$el.dataset.name
  49. var family = this.$el.dataset.family
  50. if (family) {
  51. this.family = family
  52. }
  53. }
  54. })
  55. var Offspring = Man.extend({
  56. template: document.getElementById('v-template-offspring').innerHTML.trim()
  57. })
  58. Vue
  59. .component('man', Man)
  60. .component('offspring', Offspring)
  61. new Man({
  62. el: '#grandpa'
  63. })
  64. </script>
  65. </body>
  66. </html>