nested-vms.html 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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 {{$parent.name}}</p>
  27. <div v-component="man" data-name="Mike">
  28. <p class="mike">{{name}}, son of {{$parent.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 {{$parent.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 {{$parent.name}}, grandson of {{$parent.$parent.name}}, great-grandson of {{$root.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. console.log(this.$el)
  50. console.log(this.name)
  51. var family = this.$el.dataset.family
  52. if (family) {
  53. this.family = family
  54. }
  55. }
  56. })
  57. var Offspring = Man.extend({
  58. template: document.getElementById('v-template-offspring').innerHTML.trim()
  59. })
  60. Vue
  61. .component('man', Man)
  62. .component('offspring', Offspring)
  63. new Man({
  64. el: '#grandpa'
  65. })
  66. </script>
  67. </body>
  68. </html>