js实现橱窗展示效果


Posted in Javascript onJanuary 11, 2020

本文实例为大家分享了js实现橱窗展示的具体代码,供大家参考,具体内容如下

思路

1、获取需要的标签

2、求出滚动条的长度(公式:滚动条长度 = ( 盒子的宽度 / 内容的宽度) * 盒子的宽度)

3、监听鼠标按下事件:3 设置起始位置

4、监听鼠标的移动:

4.1求出移动的位置
4.2判断滚动条的位置(防超出)
4.3 移动滚动条、商品滚动(公式:内容走的距离 = (内容的长度 - 盒子的长度) / (盒子长度 - 滚动条的长度) * 滚动条走的距离);

5、监听鼠标的离开事件:把鼠标的移动事件设置为无即可。

<script>
    window.onload = function (){
      //1.获取需要的标签
      var box = document.getElementById("box");
      var box_top = box.children[0];
      var box_bottom = box.children[1];
      var mask = box_bottom.children[0];
      //2.获取滚动条长度
      // 滚动条长度 = ( 盒子的宽度 / 内容的宽度) * 盒子的宽度
      var mask_length = (box.offsetWidth /box_top.offsetWidth) * box.offsetWidth;
      mask.style.width = mask_length + "px";
      //3.监听鼠标按下的事件
      mask.onmousedown = function (event){
        var event = event || window.event;
        //3.1设置起始位置
        var beginX = event.clientX - mask.offsetLeft;
        //3.2 监听鼠标的移动
        document.onmousemove =function (event){
          var event = event || window.event;
          //3.2.1求移动的位置
          var endX = event.clientX - beginX;

          //3.2.2处理边界值
          if(endX < 0){
            endX = 0
          }else if(endX >= box.offsetWidth - mask.offsetWidth){
            endX = box.offsetWidth - mask.offsetWidth;
          }
          //3.2.3让滚动条滚动
          mask.style.left = endX + "px";

          //3.2.4 让商品随着滚动
          //公式:内容走的距离 = (内容的长度 - 盒子的长度) / (盒子长度 - 滚动条的长度) * 滚动条走的距离
          var content_len = (box_top.offsetWidth - box.offsetWidth) / (box.offsetWidth - mask.offsetWidth) * endX;
          box_top.style.left = -content_len + "px";

          return false;
        };
        document.onmouseup = function (){
          document.onmousemove = null;
        }
      }
    }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js获取GridView中行数据的两种方法 分享
Jul 13 Javascript
基于jquery的禁用右键、文本选择功能、复制按键的实现代码
Aug 27 Javascript
18个非常棒的jQuery代码片段
Nov 02 Javascript
完美解决IE9浏览器出现的对象未定义问题
Sep 29 Javascript
利用jQuery来动态为属性添加或者删除属性的简单方法
Dec 02 Javascript
面包屑导航详解
Dec 07 Javascript
使用vue-cli编写vue插件的方法
Feb 26 Javascript
vue+axios+element ui 实现全局loading加载示例
Sep 11 Javascript
小程序文字跑马灯效果
Dec 28 Javascript
手把手带你封装一个vue component第三方库
Feb 14 Javascript
详解vuex持久化插件解决浏览器刷新数据消失问题
Apr 15 Javascript
JS实现页面鼠标点击出现图片特效
Aug 19 Javascript
vue实现购物车选择功能
Jan 10 #Javascript
webpack proxy 使用(代理的使用)
Jan 10 #Javascript
基于vue-draggable 实现三级拖动排序效果
Jan 10 #Javascript
bootstrap实现嵌套模态框的实例代码
Jan 10 #Javascript
jQuery操作动画完整实例分析
Jan 10 #jQuery
基于JavaScript判断两个对象内容是否相等
Jan 10 #Javascript
jQuery操作事件完整实例分析
Jan 10 #jQuery
You might like
mysql 性能的检查和优化方法
2009/06/21 PHP
PHP操作XML作为数据库的类
2010/12/19 PHP
PHP性能优化 产生高度优化代码
2011/07/22 PHP
PHP性能优化工具篇Benchmark类调试执行时间
2011/12/06 PHP
PHP中文件缓存转内存缓存的方法
2011/12/06 PHP
浅析关于PHP位运算的简单权限设计
2013/06/30 PHP
ThinkPHP验证码使用简明教程
2014/03/05 PHP
使用composer命令加载vendor中的第三方类库 的方法
2019/07/09 PHP
window.showModalDialog使用手册
2007/01/11 Javascript
JS实现淘宝幻灯片效果的实现方法
2013/03/22 Javascript
Node.js中的模块机制学习笔记
2014/11/04 Javascript
jQuery对象与DOM对象之间的相互转换
2015/03/03 Javascript
jQuery动画效果相关方法实例分析
2015/12/31 Javascript
xtemplate node.js 的使用方法实例解析
2016/08/22 Javascript
详解vue中使用express+fetch获取本地json文件
2017/10/10 Javascript
旺旺在线客服代码 旺旺客服代码生成器
2018/01/09 Javascript
动态Axios的配置步骤详解
2018/01/12 Javascript
JS/jQuery实现DIV延时几秒后消失或显示的方法
2018/02/12 jQuery
Angular实现svg和png图片下载实现
2019/05/05 Javascript
[49:43]VG vs FNATIC 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
使用python BeautifulSoup库抓取58手机维修信息
2013/11/21 Python
python实现根据用户输入从电影网站获取影片信息的方法
2015/04/07 Python
Python中的lstrip()方法使用简介
2015/05/19 Python
Linux下使用python自动修改本机网关代码分享
2015/05/21 Python
对Python 3.5拼接列表的新语法详解
2018/11/08 Python
python3射线法判断点是否在多边形内
2019/06/28 Python
PyCharm无法识别PyQt5的2种解决方法,ModuleNotFoundError: No module named 'pyqt5'
2020/02/17 Python
基于Tensorflow一维卷积用法详解
2020/05/22 Python
PyQt5如何将.ui文件转换为.py文件的实例代码
2020/05/26 Python
CSS3 Media Queries(响应式布局可以让你定制不同的分辨率和设备)
2013/06/06 HTML / CSS
Hobbs官方网站:英国奢华女性时尚服装
2020/02/22 全球购物
采购主管的岗位职责
2013/12/17 职场文书
超市总经理岗位职责
2014/02/02 职场文书
《九色鹿》教学反思
2014/02/27 职场文书
小学毕业感言500字
2014/02/28 职场文书
工商管理专业毕业生自我鉴定2014
2014/10/04 职场文书