animation.html 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <script src="../../../dist/vue.js"></script>
  2. <style type="text/css">
  3. h1 {
  4. display: inline-block;
  5. }
  6. .v-enter {
  7. animation: fadein .2s;
  8. -webkit-animation: fadein .2s;
  9. }
  10. .v-leave {
  11. animation: fadeout .2s;
  12. -webkit-animation: fadeout .2s;
  13. }
  14. @keyframes fadein {
  15. 0% {
  16. -webkit-transform: scale(0);
  17. transform: scale(0);
  18. }
  19. 50% {
  20. -webkit-transform: scale(1.5);
  21. transform: scale(1.5);
  22. }
  23. 100% {
  24. -webkit-transform: scale(1);
  25. transform: scale(1);
  26. }
  27. }
  28. @keyframes fadeout {
  29. 0% {
  30. transform: scale(1);
  31. -webkit-transform: scale(1);
  32. }
  33. 50% {
  34. transform: scale(1.5);
  35. -webkit-transform: scale(1.5);
  36. }
  37. 100% {
  38. transform: scale(0);
  39. -webkit-transform: scale(0);
  40. }
  41. }
  42. @-webkit-keyframes fadein {
  43. 0% {
  44. -webkit-transform: scale(0);
  45. transform: scale(0);
  46. }
  47. 50% {
  48. -webkit-transform: scale(1.5);
  49. transform: scale(1.5);
  50. }
  51. 100% {
  52. -webkit-transform: scale(1);
  53. transform: scale(1);
  54. }
  55. }
  56. @-webkit-keyframes fadeout {
  57. 0% {
  58. transform: scale(1);
  59. -webkit-transform: scale(1);
  60. }
  61. 50% {
  62. transform: scale(1.5);
  63. -webkit-transform: scale(1.5);
  64. }
  65. 100% {
  66. transform: scale(0);
  67. -webkit-transform: scale(0);
  68. }
  69. }
  70. </style>
  71. <div id="test">
  72. <h1 v-animation v-if="ok">Hahahah</h1>
  73. <br>
  74. <button v-on="click: ok = !ok">toggle</button>
  75. </div>
  76. <script>
  77. var test = new Vue({
  78. el: '#test',
  79. data: {
  80. ok: true
  81. }
  82. })
  83. </script>