Skip to content

Latest commit

 

History

History
254 lines (183 loc) · 6.3 KB

README.md

File metadata and controls

254 lines (183 loc) · 6.3 KB

原生 JS 撸一个轮播图(支持拖拽切屏)

FoxSlider.js 称不上库的库 在线page

last update time: 2019-08-15

  • 修复轮播图边界时滚动不流畅
  • 新增 2个轮播图样式点我去看效果
  • IE9的一些兼容性修复

1、简述

用惯了各种各样的组件,并没有真正意义上的封装一个可以拖拽切屏的轮播图,经过一番编写,发现写这样一个轮播图要想写的好,还真的是挺有难度,不同设备的不同事件完备性?事件触发时机的把控?如何更好的去封装?自适应窗口后的事件重置?等等...,看看swiper这个库的源码,就知道小事情也可以不简单。
现在写的这个基本的需求是可以满足的,可以通过拖拽切换也可以点击切换。

(想你来一起完(wan)善(shua)!!Fork & Star ^_^一下你就会很美

原生撸码一时爽,一直原生一直爽

1.1、特性

  • 面向手机、平板,PC等终端。

1.2、缺点

  • 功能亟需扩充
  • 用户配置功能有待扩充
  • 轮播图样式不够丰富
  • 性能待测

2、调用实例

html 结构代码

<!-- 引入js,css文件 -->
<link href="./css/index.css">
<script src="./js/base.js"></script>
<!-- 主要dom结构 -->
<h2>样式一:</h2>
<div class="slider-container slider-identifier">
  <div class="slide-bar">
    <div class="slider "><img src="./src/assets/slider1.jpg"></div>
    <div class="slider"><img src="./src/assets/slider2.jpg"></div>
    <div class="slider"><img src="./src/assets/slider3.jpg"></div>
    <div class="slider"><img src="./src/assets/slider2.jpg"></div>
    <div class="slider"><img src="./src/assets/slider3.jpg"></div>
  </div>
  <div class="slider-pin">
    <span class="pin on"></span>
    <span class="pin"></span>
    <span class="pin"></span>
    <span class="pin"></span>
    <span class="pin"></span>
  </div>
</div>

js 代码

//样式1
var tp = new TouchPlugin({
  sliderContainer:'.slider-identifier.slider-container',
  slider:'.slider-identifier .slider',
  slidePin:'.slider-identifier .slider-pin',
  sliderBar:'.slider-identifier .slide-bar',
  pinClassName:'on',
  pin:'.slider-identifier .pin',
  callback:function(e, dir, distance){}
});

运行效果

运行效果图

3、base.js内主要方法

init()

初始化函数

Kind: global function


refreshParam(totalMoveLen, spinIndex)

刷新参数

Kind: global function

Param Type Description
totalMoveLen number 滚动位移
spinIndex number 轮播指标高亮下标

setTranslate(domNode, conf, moveLen)

设置指定对象移动样式 (transform)

Kind: global function

Param Type Description
domNode Object 应用移动样式的对象
conf Object 配置对象(animateStyle: ease-in-out
moveLen number 轮播图移动距离(切屏通过控制位移)

resize()

改变屏幕尺寸重置参数

Kind: global function


autoRun(time, initStep)

自动轮播

Kind: global function

Param Type Description
time number 轮播时间
initStep number spin下标 和下一屏

judgeDir(curX, preX)

判断鼠标或触摸移动的方向

Kind: global function

Param Type Description
curX number 鼠标点击或开始触摸屏幕时的坐标X
preX numer 鼠标移动或触摸移动时的坐标X

testTouchEvent()

检测当前设备支持的事件(鼠标点击移动和手触摸移动)

Kind: global function


mouseX(event)

获取鼠标横坐标位置

Kind: global function

Param Type Description
event Event 事件对象

cancelBind(domNode)

取消绑定触摸或鼠标点击移动事件

Kind: global function

Param Type Description
domNode Object 需要被取消绑定事件节点对象

reBindTouchEvent(domNode, callback, isUnbind)

重新绑定触摸事件

Kind: global function

Param Type Description
domNode Object 需要被绑定事件节点对象
callback function 回调方法
isUnbind boolean 是否取消绑定

removeClsName(nodeList, clsName)

移除节点的样式类名

Kind: global function

Param Type Description
nodeList Array 被移除样式的节点数组
clsName string 移除的样式类名称

setClsName(node, clsName)

添加样式

Kind: global function

Param Type Description
node Object 添加类名的节点
clsName string 样式类名

bindSpinClick()

点击轮播spin 切换屏

Kind: global function


bindLeftRightBtnClick()

点击左右按钮切换屏

Kind: global function


checkTargetByCls(domNode, clsName)

通过检测dom节点是否包含某个样式名来判断是否属于目标target

Kind: global function

Param Type
domNode Object
clsName string

bindTouchEvent(domNode, callback, isUnbind)

Kind: global function

Param Type Description
domNode Object 绑定事件的代理对象
callback function 回调方法
isUnbind boolean 是否取消绑定