0

0

手机端实现Bootstrap图片轮播的效果

不言

不言

发布时间:2018-06-25 11:50:47

|

2749人浏览过

|

来源于php中文网

原创

这篇文章主要为大家详细介绍了基于bootstrap的简单轮播图的手机实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

个人电脑里存了不少适合手机欣赏的图片,但是放手机里看是件很占据资源的事。鉴于家里有一台电脑经常开着,正好用来做家庭局域网共享,于是笔者就设想通过一种比较简单环保的思路。通过手机访问电脑内的图片。

首先是本地站点搭建:win+R输入mmc打开控制台,文件-添加/删除管理单元,Internet信息服务。添加确定,右侧基本信息,新建网站-把路径改了。设定一个端口号,手机浏览器就可以输入  电脑局域网ip:端口号 就可以连上去了。

接下来问题来了,一个个点击查看然后关闭图片是一件更不环保的事。何不做一个网页访问呢?最简单的就是选项卡-轮播图的模式。鉴于bootstrap的易适配性,就直接用它吧。 

一. 初始化设置:

按钮组(ul-li-button)(太长,所有overflow hidden,需要滑动显示),按钮组是根据实际情况用DOM生成的,进入页面默认显示第一页红色高亮显示。
跳转按钮:一文本输入框,一个button风格的input
美图展示区 

二. 页面主要实现三个功能,每个功能要实现三类相似的效果:

1. 手指点击页面可以自动切换

左右区域被点击
思路,做两个透明的绝对定位p一左一右,覆盖img层上方。点击时可以触发事件:
(1)按钮组颜色变化
(2)按钮组滑动
(3)图片切换
这里有个谁控制谁的问题,需要选取点击一瞬间的红色按钮,然后变变蓝,下一个(上一个)变红。
(ul-li-button)体系中,按钮组滑动距离应该是当前的基础上前进或后退一个li的宽度单位。但是自适应的按钮个位数和十位数宽度不同。需要分类讨论之。
图片根据变化后红色按钮内的序号改变显示的图片。
所以是序列按钮控制所有功能 

2.点击按钮页面切换

事件——序列按钮被点击
(1)点击按钮颜色变化——被点击的按钮变红,其它变蓝——不难
(2)按钮组滑动目标位置——用的是当前按钮的left值,加上少算ul-lipadding的15——就算出了当前button相对于ul的偏移。然后,把此偏移作为ul相对于显示区的偏移值。(如果愿意,可以加上一个值,让按钮看起来居中)
(3)图片切换,根据变化后红色按钮内的序号改变显示的图片。
此过程1依然是序列按钮控制所有功能。 

3.输入跳转
事件——跳转按钮被点击
(1)按钮变色,根据输入框内的value值,用原生js把该含有该序号的按钮选出来。变红
(2)按钮组滑动——跟前面一样
(2)图片切换,跟前面一样。
此过程是输入框控制页面的所有功能。 

根据这个思想,大致的功能就实现了。 

三 .有几个原则:
(1)动画控制:手持设备的特性允许用户以很快的手速点击屏幕,频繁地触发事件导致按钮不能停止。可以用判断动画函数来阻止运行。但是这样做让页面生硬。可以考虑用淡出——改变图片路径(延迟执行)——淡入的方式,及解决了快手速用户问题,也能在一定程度上提升柔和感,
(2)极限控制,当第一页和最后一页时,应阻止用户再操作。
(3)图片为了网页应该做一定的修改,本例采用的图片命名为xxx (1) ,xxx (2)。。。。的方式,因为有一个流水号所以DOM操作起来很方便。

四. 进一步应用

写了那么多代码,只用在一个套图页面上面,就太不环保了。所以把它们封装为函数。传入两个参数:url 和 imgNum分别代表图片路径和套图数量。
url是一个字符串,必须满足下面要求:
图片文件名必须夹杂 “(流水号)”,对文件夹名等无要求,比如 “文静/wenjing().jjpg” 系列流水号由js生成。所以不用写。
实现手段是slice()方法。 

五.问题

支持电脑手机端的幻灯片轮播效果
支持电脑手机端的幻灯片轮播效果

支持电脑手机端的幻灯片轮播代码

下载

首次加载时动画显示滞后,是因为需要时间下载所致,可以通过适当延长动画时间。在家庭共享环境下,可以忽略这个问题。
可能存在因为bootstrap特性,所以有若干自定样式的表现不符合设计的规范。 

效果图:(适配ip6)

 

demo地址:(建议手机观看)http://djtao.top/ugirl/ 

代码清单html 



 
 
 
 
  
 
 
  
 
 
 
 
 
 
  
 Ugirl
  
 
  
 
 
  
 
 
 
 
  
 
 
 
 
 
 
  
  
  
 
 
 

Ugirl 专业的秘密

    手机端实现Bootstrap图片轮播的效果

    css

    body{
     background: #f2f2f2;
    }
    #box{
     position: relative;
    }
    #next{
     width:50%;height:500px;
     position: absolute;
     left:50%;
    }
    #last{
     width:50%;height:500px;
     position: absolute;
     
    }
    #btn-group{
     height: 40px;
     overflow: hidden;
    }
    #list{
     list-style: none;
     position: absolute;
    }
    #list>li{
     list-style: none;
     float: left;
     position: relative;
    }
    #main{
     margin-top: 20px;
    }

    javascript

    function Ugirl(url,imgNum){
     
     var aBtn=document.getElementsByTagName('button');
     $('#list').css('width',(imgNum*(52))+'px');
     var str=url;
     var index=0;
     for(i=0;i');
     $btn.appendTo($('#list'));
     }
     aBtn[0].className='btn btn-danger';
     //按钮初始化设置
     //手指点击事件
     $('#box p').click(function(){
      
     if($(this).attr('id')=='next'){//下一个
      if($('.btn-danger') .html()==imgNum){
      alert('到底了哦');
      return false;
      }
      liWidth=44;
      liWidth2=52;
      
      $('.btn-danger').removeClass().addClass('btn btn-primary')
      .parent().next().children().removeClass().addClass('btn btn-danger');
     
     }else if($(this).attr('id')=='last'){//上一个
      if($('.btn-danger') .html()==1){
      alert('到顶了哦');
      return false;
      }else{
      $('.btn-danger').removeClass().addClass('btn btn-primary')
       .parent().prev().children().removeClass().addClass('btn btn-danger');
      liWidth=-44;
      liWidth2=-52;
      } 
     }else{
      return false;
     };
     //个位数按钮和10位数按钮宽度不同。所以设置两个
     if($('.btn-danger') .html()<=10){
      
      $('#list').animate({left:'-='+liWidth+'px'},400);
      
     }else if($('.btn-danger') .html()>10){
      
      $('#list').animate({left:'-='+liWidth2+'px'},400);
     }
     //大图切换
     $('img').fadeOut(200);
     setTimeout(function(){
      $('img').attr('src',a+$('.btn-danger') .html()+b);
     },220)
     $('img').fadeIn(300);
     });
     //选项按钮点击
     $('button').click(function(){ 
     $('button').attr('class','btn btn-primary');
     $(this).attr('class','btn btn-danger');
     var moveLength=-$(this).parent().position().left+15;
     $('#list').animate({left:moveLength+'px'},400);
     $('img').attr('src',a+$('.btn-danger') .html()+b); 
      
     });
     //跳转按钮点击
     $('.btn-default').click(function(){
     var s=$('#num').val();
     if(s<1||s>imgNum){
      return false;
      alert('没有那么多哦')
     }//极限设置
     var pageNum=$('.btn-danger') .html();
     $('img').attr('src',a+s+b);
     $('#list').children().children().removeClass().addClass('btn btn-primary');
     $(aBtn[s-1]).removeClass().addClass('btn btn-danger');
     var moveLength=-$(aBtn[s-1]).parent().position().left+15;
     $('#list').animate({left:moveLength+'px'},400);
     })
    }
    $(function(){
     Ugirl('img/wenjing/wenjing ().jpg',65);
    })//在其它页面也引入了Ugirl函数后,就可以直接调用直接调用

    以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

    相关推荐:

    bootstrap时间控件daterangepicker的使用方法

    关于Bootstrap中form和navbar使用方法的解析

    相关专题

    更多
    php文件怎么打开
    php文件怎么打开

    打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

    1933

    2023.09.01

    php怎么取出数组的前几个元素
    php怎么取出数组的前几个元素

    取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

    1273

    2023.10.11

    php反序列化失败怎么办
    php反序列化失败怎么办

    php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

    1176

    2023.10.11

    php怎么连接mssql数据库
    php怎么连接mssql数据库

    连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

    948

    2023.10.23

    php连接mssql数据库的方法
    php连接mssql数据库的方法

    php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

    1400

    2023.10.23

    html怎么上传
    html怎么上传

    html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

    1229

    2023.11.03

    PHP出现乱码怎么解决
    PHP出现乱码怎么解决

    PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

    1439

    2023.11.09

    php文件怎么在手机上打开
    php文件怎么在手机上打开

    php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

    1303

    2023.11.13

    桌面文件位置介绍
    桌面文件位置介绍

    本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

    0

    2025.12.30

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 2.7万人学习

    前端开发(基础+实战项目合集)
    前端开发(基础+实战项目合集)

    共60课时 | 3.7万人学习

    第二十四期_前端开发
    第二十四期_前端开发

    共161课时 | 4.3万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号