index.vue 887 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <template>
  2. <div class="r-img">
  3. <div class="r-normal" @click="clickHandle">
  4. <img :src="imgs[0].img" alt>
  5. </div>
  6. <div class="rotate">
  7. <img :src="imgs[1].img" alt>
  8. </div>
  9. </div>
  10. </template>
  11. <script>
  12. export default {
  13. props: ['imgs'],
  14. methods: {
  15. clickHandle () {
  16. this.$emit('clickHandle')
  17. }
  18. }
  19. }
  20. </script>
  21. <style scoped>
  22. .r-img {
  23. position: relative;
  24. }
  25. .r-img div {
  26. width: 20vw;
  27. height: 15vw;
  28. position: absolute;
  29. top: 0;
  30. z-index: 99;
  31. border: 8px #fff solid;
  32. box-sizing: border-box;
  33. overflow: hidden;
  34. }
  35. .r-img div img {
  36. transition: transform 0.3s ease;
  37. width: 100%;
  38. height: 100%;
  39. }
  40. .r-img div:hover img {
  41. transform: scale(1.1);
  42. transition: transform 0.3s ease;
  43. }
  44. .r-img .rotate {
  45. transform: rotate(17deg);
  46. z-index: 0;
  47. }
  48. @media screen and (max-width: 1400px) {
  49. .r-img div {
  50. top: 18vw;
  51. }
  52. }
  53. </style>