前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用css就能很好的解决这功能

一、直接上代码。

  1.  
    <!DOCTYPE html>
  2.  
    <html xmlns="http://www.w3.org/1999/xhtml">
  3.  
    <head>
  4.  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5.  
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
  6.  
    <script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.min.js"></script>
  7.  
    <title>test</title>
  8.  
    <style>
  9.  
    body,ul { margin:0; padding:0;}
  10.  
    .concent { margin:50px auto; width:100%; max-width:750px; min-width:320px; }
  11.  
    .box { white-space:nowrap; overflow-x:auto; } /*注释1*/
  12.  
    .box::-webkit-scrollbar { width:0; height:0; display: none; } /*注释2*/
  13.  
    li { list-style:none; display:inline-block; width:100px; line-height:30px; margin-right:10px;
  14.  
    background:#ccc; text-align:center; } /*注释3*/
  15.  
    li:last-child { margin:0; }
  16.  
    </style>
  17.  
    </head>
  18.  
    <body>
  19.  
    <div class="concent">
  20.  
    <ul class="box"> <!-- /*注释4*/ -->
  21.  
    <li>简简单单</li><li>
  22.  
    简简单单</li><li>
  23.  
    简简单单</li><li>
  24.  
    简简单单</li><li>
  25.  
    简简单单</li><li>
  26.  
    简简单单</li>
  27.  
    </ul>
  28.  
    </div>
  29.  
    <script>
  30.  
    var u = navigator.userAgent;
  31.  
    var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1; //android终端
  32.  
    var isUc = u.indexOf('UCBrowser') > -1; //uc浏览器
  33.  
    //var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端
  34.  
    if(isAndroid&&isUc){ /*注释5*/
  35.  
    $('.box').on('touchstart',function(){
  36.  
    $(document).on('touchmove',function(e){
  37.  
    e.preventDefault();
  38.  
    });
  39.  
    $(document).on('touchend',function(){
  40.  
    $(document).unbind();
  41.  
    });
  42.  
    });
  43.  
    }
  44.  
    </script>
  45.  
    </body>
  46.  
    </html>

运行代码,发现就可以实现左右滑动了。

二、注释解析与注意事项。

注释①,注释③:改变li标签为行内块元素(inline-block),给ul添加一个white-space:nowrap; 不让他自动换行。再添加overflow-x:auto;让他超出部分滚动显示。

注释④ : 是为了解决行内块元素之间的默认间隙问题。(关于行内块间隙问题可以查看【css】行内元素、行内块元素的默认间隙问题)。

注释②: ::-webkit-scrollbar { width:0; height:0; display: none; } 是为了解决安卓浏览器的滚动条问题,在iphone浏览器上的常规浏览器上不会出现横向的滚动条,但是在安卓设备上的chrome,火狐浏览器等一些浏览器会出现滚动条,安卓设备上高版本的uc浏览器,qq自带浏览器,微信自带浏览器不会出现滚动条。(该方法无法解决火狐浏览器出现的滚动条,网上查找了蛮多资料,都建议js去解决这问题)。

注释⑤:是为解决安卓设备上的uc浏览器一个恶心的功能,就是安卓设备上的uc浏览器如果打开好几个窗口页面。向左向右滑的时候会跳转到其他页面,这时就需要取消默认事件。

三、(补充)通过scrollLeft,点击li标签进行位置滑动

  1.  
    <!DOCTYPE html>
  2.  
    <html xmlns="http://www.w3.org/1999/xhtml">
  3.  
    <head>
  4.  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5.  
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
  6.  
    <script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.min.js"></script>
  7.  
    <title>test</title>
  8.  
    <style>
  9.  
    body,ul { margin:0; padding:0;}
  10.  
    .concent { margin:50px auto; width:100%; max-width:750px; min-width:320px; position:relative; }
  11.  
    .box { white-space:nowrap; overflow-x:auto; position:relative; }
  12.  
    .box::-webkit-scrollbar { width:0; height:0; display: none; }
  13.  
    li { list-style:none; display:inline-block; line-height:30px; margin-right:20px;
  14.  
    background:#ccc; text-align:center; }
  15.  
    </style>
  16.  
    </head>
  17.  
    <body>
  18.  
    <div class="concent">
  19.  
    <ul class="box">
  20.  
    <li>11111111</li><li>
  21.  
    22222222</li><li>
  22.  
    33333333</li><li>
  23.  
    44444444</li><li>
  24.  
    55555555</li><li>
  25.  
    66666666</li><li>
  26.  
    77777777</li><li>
  27.  
    88888888</li><li>
  28.  
    99999999</li>
  29.  
    </ul>
  30.  
    </div>
  31.  
    <script>
  32.  
    var oBox = $('.box');
  33.  
    var oBoxWidth = $('.box').width();
  34.  
     
  35.  
    oBox.find('li').on('click',function(){
  36.  
    var thisWidth = $(this).width();
  37.  
    var moveLeft = this.offsetLeft;
  38.  
    if(oBoxWidth<moveLeft+thisWidth){
  39.  
    oBox.animate({scrollLeft:moveLeft});
  40.  
    }else{
  41.  
    oBox.animate({scrollLeft:0});
  42.  
    }
  43.  
    });
  44.  
    </script>
  45.  
    </body>
  46.  
    </html>

运行代码,就可以看到,我们点击哪个li标签,该li标签就会滑到前面的位置,当我们点击最后几个li标签,也不会说滑动位置过大,导致后面空白,如果我们用js解决的话,也还要去限制他的最大滑动距离,而通过css滚动,不需要担心这问题。

【css】用css巧妙实现移动端横向滑动展示功能的更多相关文章

  1. 用css巧妙实现移动端横向滑动展示功能

    前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用cs ...

  2. 纯css实现移动端横向滑动列表

    前几天在公司做开发的时候碰到一个列表横向滑动的功能,当时用了iscroll做,结果导致手指触到列表的范围内竖向滑动屏幕滑动不了的问题. 这个问题不知道iscroll本身能不能解决,当时选择了换一种方式 ...

  3. 纯css实现移动端横向滑动列表(可应用于ionic3移动app开发)

    前几天在公司做开发的时候碰到一个列表横向滑动的功能,当时用了iscroll做,结果导致手指触到列表的范围内竖向滑动屏幕滑动不了的问题. 这个问题不知道iscroll本身能不能解决,当时选择了换一种方式 ...

  4. 纯css实现移动端横向滑动列表&&overflow:atuo;隐藏滚动条

    <!DOCTYPE html> <html> <head> <title>横向滑动</title> <style type=" ...

  5. CSS实现移动端横向滑动

    html: <div class="chosen-container"> <div class="chosen-swiper"> < ...

  6. CSS+HTML实现移动端div左右滑动展示

    由于手机屏幕的宽度有限,内容太多移动设备一行装不下的,所以很多移动端网站的导航栏都有左右滑动效果,下面我就用CSS+HTML实现移动端div左右滑动展示. CSS:box设置文本不换行,子元素box1 ...

  7. CSS Sprites (CSS图像拼合技术)教程工具

    什么是CSS Sprites? “Sprite”(精灵)这个词在计算机图形学中有它独特的定义,由于游戏.视频等画质越来越高,必须有一种技术可以智能的处理材质和贴图,并且要 同时保持画面流畅.“Spri ...

  8. CSS Sprites(CSS图像拼合技术)教程、工具集合

    本集合是有一位国外设计师收集整合,并由 oncoding翻译成中文的,感谢他们的辛苦贡献.CSS Sprites技术在国外并不是什么新技术,只不过近两年(尤其08年开始)中国开始流行这个词,大家也开始 ...

  9. 【Python全栈-CSS】CSS入门

    CSS入门教程 参考: http://www.cnblogs.com/yuanchenqi/articles/5977825.html http://www.ruanyifeng.com/blog/2 ...

随机推荐

  1. Ansible-Tower使用文档

    导航栏介绍 # viewes Dashboard 仪表盘展示信息的 Jobs 跑过的任务记录 Schedules 计划任务 My View 查看用户的工作模版,和任务记录 # resources Te ...

  2. BZOJ 4239: 巴士走读 最短路

    显然,我们可以将询问按照规定时间从小到大排序,依次处理. 那么我们显然要求合法的点中从 $n$ 号点出发到达点 $i$ 的最迟时间,我们令这个为 $f[i]$ 而 $f[i]$ 显然可以用最短路来求. ...

  3. 谷歌 AI 负责人谈2020 年机器学习趋势:多任务和多模态会有大突破

    ​在上周加拿大温哥华举行的NeurIPS会议上,机器学习成为了中心议题. 来自世界范围内约1.3万名研究人员集中探讨了神经科学.如何解释神经网络输出以及人工智能如何帮助解决现实世界中的重大问题等焦点话 ...

  4. ASP.NET MVC中ActionResult的不同返回方式

    1.返回视图 return View();//返回方法名对应的视图 return View("aaa");//返回名称为aaa的视图 2.返回文本内容 return Content ...

  5. 2级搭建类204-Oracle 12cR2 SI ASM 图形化搭建(RHEL7.6)

    红帽RHEL 7.6上搭建Oracle 12cR2 ASM单实例 我给你们说,不是自家的产品,那贼麻烦,你是不是觉得在 红帽 7.6 上搞 12c ASM 觉得应该/好像/可能/或许/貌似/大概/也许 ...

  6. 137.在Django中操作session

    在Django中操作session 在django中session默认情况下是存储在服务器的数据库中的,在表中会根据sessionid来提取指定的session数据,然后再把这个sessionid放到 ...

  7. 风变编程笔记(一)-Python基础语法

    第0关  print()函数与变量 1. print()函数print()函数:告诉计算机,把括号的内容显示在屏幕上 # 不带引号 print(1+1) # 让计算机读懂括号里的内容,打印最终的结果 ...

  8. 【Unity|C#】基础篇(2)——栈与堆、值类型与引用类型

    传送门:https://www.cnblogs.com/moonache/p/6008048.html [笔记] 图1:值类型与引用类型 存储方式 > 值类型:数据直接存在栈中 > 引用类 ...

  9. R语言函数化学习笔记3

    R语言函数化学习笔记3 R语言常用的一些命令函数 1.getwd()查看当前R的工作目录 2.setwd()修改当前工作目录 3.str()可以输出指定对象的结构(类型,位置等),同理还有class( ...

  10. SpringData JPA快速入门和基本的CRUD操作以及Specifications条件查询

    SpringData JPA概述: SpringData JPA 是 Spring 基于 ORM 框架.JPA 规范的基础上封装的一套JPA应用框架,可使开发者用极简的代码即可实现对数据库的访问和操作 ...