data:image/s3,"s3://crabby-images/46c1c/46c1cebf6ec2b9b425922415ad345e722671824f" alt=""
官网链接直达
首先在项目首页H5中有使用到banner,自动滚动,如图所示
data:image/s3,"s3://crabby-images/a0946/a09468f8a08b09cdb8feac8df37b9fd87a45da86" alt=""
默认有4张图片,从后台取出数据之后,重新给这4张图片的src赋值.
赋值之后,发现第一张和最后一张怎么都不出来,开始以为是地址问题
好的,各种调试log ,发现地址没问题
或者获取的DOM 节点有问题?各种console ,还是问题
是对象的类型有问题?试着用js 原生对象 juqery 对象 angular js element 对象
试了都无果,实在是心累,不知道哪里的问题,把官网的API 翻了个遍,还是没找到问题
难道问题是出在布局上面?
来看看布局
data:image/s3,"s3://crabby-images/e8dda/e8dda1aff4d1f0e8ff4756c34e6c9ce460996762" alt=""
swiper-container 下面除了4张图和页标之外还有这个,立马delete
调试,还是出不来.... 一口老血喷出...(这里确实有问题,但是不是图片的问题这个问题后面说)
是在不知道怎么办了.... 看看DOM 节点吧....在Chrome 中打开网页....
data:image/s3,"s3://crabby-images/e68a9/e68a95b797adae9aad1be7c3daf96ad7fb753aff" alt=""
我去.老子当时是这个表情
data:image/s3,"s3://crabby-images/83f32/83f32a61e85285051f75508950f4bfef799f15da" alt=""
居然有6个DIV ,我4张图居然给我生成了6个div ,恍然大悟,原来是swiper 内部为了循环滚动,多生成了两个div
仔细查看问题之后,重新赋值,问题解决.
data:image/s3,"s3://crabby-images/a59fe/a59fe9f6d34baac6ecca4fa7bdeacc9ffc9b0358" alt=""
再来看看另外一个问题,banner图片要点击,点击之后要跳转原生,来看看原来的代码
data:image/s3,"s3://crabby-images/ff25a/ff25a402d77e8a49e6dada6cca2f8e6f4a2e602e" alt=""
??? -0 +1 ...
switch 下面的代码除了index 一模一样......
于是把switch里面重复的代码提取出来,但是这个indexImg 得重新获取一下,心想这个框架肯定能直接能取到当前的activeIndex ,于是官网走一波
data:image/s3,"s3://crabby-images/7b10c/7b10cd302ea367d0a6996946f71fb0be1207fd4c" alt=""
返回了个swiper对象,再去看看这个对象
data:image/s3,"s3://crabby-images/cbcfe/cbcfe3bf75b95c8f7c791551a067464d00fd16f6" alt=""
这不是吗?马上使用这个对象,可是经过调试,index 根本不对...
第一张图的index 是2 ,意思就是从2开始的. 2,3,4,5
.........
开始以为是API使用问题,把官方的使用示例看了一遍没问题啊
查看DOM节点之后发现,在swiper-container 下面除了4张图和页标之外下面还有2个div,删除试试?这就是上面说的那个问题
删除之后索引正常.....
但是页面布局不敢提出来,要重新写布局,直接-2吧.修改之后的代码
data:image/s3,"s3://crabby-images/dcd81/dcd81d1de076a4448779fd7297293302d481bdae" alt=""
总结:在JavaScript 中,问题无法得到解决的时候,需要使用chrome 调试工具,查看DOM 节点,从Dom 布局上来寻找一下问题
网友评论