当前位置:Gxlcms > JavaScript > vue+swiper实现组件化开发的实例代码

vue+swiper实现组件化开发的实例代码

时间:2021-07-01 10:21:17 帮助过:7人阅读

swiper的组件

  1. <template>
  2. <div class="swiper-container">
  3. <div class="swiper-wrapper">
  4. <div class="swiper-slide" v-for="item in swiper"><img :src="item.room_src" alt=""></div>
  5. <!--<div class="swiper-slide" v-for="item in test"><img :src="item.room_src" alt=""></div>-->
  6. </div>
  7. </div>
  8. </template>
  9. <script>
  10. import Swiper from 'swiper'
  11. export default {
  12. name: 'swiper',
  13. data() {
  14. return {
  15. mySwiper: null,
  16. // test: [
  17. // "https://rpic.douyucdn.cn/acrpic/171024/288016_0921.jpg",
  18. // "https://rpic.douyucdn.cn/acrpic/171024/748396_0924.jpg",
  19. // "https://rpic.douyucdn.cn/acrpic/171024/453751_0922.jpg",
  20. // "https://rpic.douyucdn.cn/acrpic/171024/79663_0920.jpg"
  21. // ]
  22. }
  23. },
  24. props: ['swiper'], //swiper的就是test这个数据传递来的
  25. methods: {
  26. _initSwiper() {
  27. this.mySwiper = new Swiper('.swiper-container', {
  28. autoplay: 5000,//可选选项,自动滑动
  29. })
  30. },
  31. _updateSwiper() {
  32. this.$nextTick(() => {
  33. this.mySwiper.update(true); //swiper update的方法
  34. })
  35. },
  36. swiperUpdate() {
  37. if (this.mySwiper) { //节点存在
  38. this._updateSwiper(); //更新
  39. } else {
  40. this._initSwiper(); //创建
  41. }
  42. },
  43. },
  44. watch: {
  45. //通过props传来的数据 和 组件一加载节点就创建成功 二者不是同步,实时监听的swiper(传递的值)的变化
  46. swiper() {
  47. this.swiperUpdate();
  48. }
  49. },
  50. mounted() {
  51. this.swiperUpdate(); //页面一加载拉去数据创建节点
  52. }
  53. }
  54. </script>
  55. <style lang="scss" scoped>
  56. .swiper-container {
  57. width: 100%;
  58. height: 4rem;
  59. margin-top: 0.9rem;
  60. .swiper-wrapper {
  61. width: 100%;
  62. height: 100%;
  63. .swiper-slide {
  64. background-size: cover;
  65. width: 100%;
  66. height: 4rem;
  67. img {
  68. width: 100%;
  69. height: 100%;
  70. }
  71. }
  72. }
  73. }
  74. </style>

home.vue 调用的组件方法

  1. //html
  2. <swiper :swiper="roomList.slice(6,10)" ></swiper>
  3. //js
  4. import swiper from 'components/swiper/swiper'
  5. components: {
  6. swiper
  7. },

问题:如果单纯的调用_initSwiper的方法,会发现页面是不能滚动的,但是页面随便修改东西,然后保存的swiper又可以滚动的,这个个原因是初始swiper的节点没有创建成功,值页面有穿进去的,一层一层的可以打印swiper的值为空的,当修改东西值就能传递进去的,所以的这里的我们需要通过判断节点是否成功来update siwper的方法

人气教程排行