当前位置:   article > 正文

VUE实现轮播图案例_vue轮播图案例

vue轮播图案例

实现思路:

1.将vue的框架封装在function中,在界面刷新时调用,将要轮播的图片存放在data中,还有下面的列表也分别保存在data中的一个数组中,然后每隔一段时间进行自动切换的函数写在methods中,注意函数要调用的话,就要在生命周期函数中调用,不然的话就没有用。
2.认识到这里需要的是setinterval()、而不是setimeout()函数:

  • setTimeout()和setInterval()经常被用来处理延时和定时任务。
  • setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则可以在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。
  • setTimeout()只执行一次,而setInterval可以多次调用。
  • n的设置:方便我们进行操作,比如循环到第几个,下面的小黑点也相应的变色,并且控制循环播放,当n等于数组的个数时,自动置0,从头开始。
  • html页面写好大的框架后,用v-for来控制,需要注意的是用v-for的时候一定要加上:key,

源码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>Document</title>
  7. <style>
  8. *{
  9. margin:0;
  10. padding:0;
  11. }
  12. ul {
  13. list-style-type:none;
  14. }
  15. body {
  16. font-size: 14px;
  17. background: #fff;
  18. overflow-y:scroll;
  19. overflow-x:hidden;
  20. }
  21. html,body {
  22. max-width:720px;
  23. height:100%;
  24. margin:0 auto;
  25. }
  26. .index-content .banner {
  27. position: relative;
  28. }
  29. .index-content .banner .banner-circle {
  30. position: absolute;
  31. bottom: 5px;
  32. left: 0;
  33. right: 0;
  34. color: #fff;
  35. }
  36. .index-content .banner .banner-circle li{
  37. display:inline-block;
  38. background: rgba(0,0,0,.3);
  39. border-radius: 50%;
  40. padding:5px;
  41. margin:2px;
  42. }
  43. .index-content .banner .banner-circle ul {
  44. text-align: center;
  45. }
  46. .index-content .banner .banner-circle .selected {
  47. background: rgba(0,0,0,.8);
  48. }
  49. .index-content .banner img {
  50. width: 100%;
  51. margin: 0;
  52. padding: 0;
  53. }
  54. h1{
  55. margin-left: 300px;
  56. }
  57. </style>
  58. <script type="text/javascript" src="js/vue.min.js"></script>
  59. </head>
  60. <body>
  61. <div class="index-content" id="app">
  62. <div class="banner">
  63. <h1>轮播图</h1>
  64. <img v-for="(v,i) in img " :key="i" :src="v" v-show="i==n"/>
  65. <div class="banner-circle">
  66. <ul>
  67. <li v-for="(v,i) in img " :key="i" :class="i==n ?'selected':''"></li>
  68. </ul>
  69. </div>
  70. </div>
  71. </div>
  72. <script>
  73. window.onload = function(){
  74. new Vue({
  75. el:"#app",
  76. data:{
  77. img:[
  78. "./images/1.jpg",
  79. "./images/2.jpg",
  80. "./images/3.jpg",
  81. "./images/4.jpg"
  82. ],
  83. n:2
  84. },
  85. methods:{
  86. fun:function(){
  87. //setInterval(函数体,时间)
  88. setInterval(this.play,2000)
  89. },
  90. play:function(){
  91. this.n++;
  92. if(this.n == this.img.length){
  93. this.n = 0;
  94. }
  95. }
  96. },
  97. //生命周期 钩子函数 挂载完成
  98. mounted:function(){
  99. this.fun()
  100. }
  101. })
  102. }
  103. </script>
  104. </body>
  105. </html>

效果图: 

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/251124
推荐阅读
相关标签
  

闽ICP备14008679号