zoukankan      html  css  js  c++  java
  • 手机端左右滑动效果

    刚开始试了其他的方法,好像都不行,最后找到了一个不错的插件,代码没多少,稍微改了下。

    var global = this;

    function begin() {
    setGuideWidth()
    }
    window.onload = function() {
    setGuideWidth()
    };

    function rollDelay(j, c, g, h) {
    clearInterval(global[h]);
    var i = 0;
    global[h] = setInterval(function() {
    var a = Math.exp( - g * i) * c;
    j.scrollLeft += a;
    moveBalloon(j);
    if (Math.abs(a) < 10) {
    setImgSrc(j);
    if (Math.abs(a) <= 1) {
    clearInterval(global[h])
    }
    }
    i++
    },
    16)
    }

    function calcWidth(m) {
    var i = [];
    var l = m.getElementsByClassName("page_guide_item_text");
    for (var o = 0; o < l.length; o++) {
    i[o] = l[o].clientWidth * 1.11;
    var j = l[o].parentElement.getElementsByTagName("img");
    for (var p = 0; p < j.length; p++) {
    i[o] += j[p].clientWidth + 12
    }
    }
    var n = 0;
    for (var o = 0; o < i.length; o++) {
    n += i[o]
    }
    var k = m.parentElement.parentElement.id;
    global[k + "_cw"] = n;
    global[k + "_aw"] = i;
    if (n < document.body.clientWidth) {
    n = document.body.clientWidth
    }
    }
    function setGuideWidth() {
    var d = document.getElementsByClassName("page_guide_container");
    for (var c = 0; c < d.length; c++) {
    calcWidth(d[c]);
    setProgress(d[c]);
    setImgSrc(d[c])
    }
    }
    function setProgress(l) {
    var j = l.parentElement.parentElement.id;
    var i = global[j + "_aw"];
    var m = global[j + "_cw"];
    // h.innerHTML = "";
    for (var n = 0; n < i.length; n++) {
    var k = document.createElement("div");
    k.style.width = i[n] / m * 100 + "%";
    if (n % 2 == 0) {
    k.style.backgroundColor = "#83A0A5"
    }
    }
    }
    function moveBalloon(w) {
    var B = w.parentElement.parentElement.id;
    var u = global[B + "_aw"];
    var A = global[B + "_cw"];
    var s = w.scrollLeft / (A - document.body.clientWidth);
    var z = s * A;
    for (var x = 0; x < u.length; x++) {
    z -= u[x];
    if (z < 0) {
    if (global[B + "_ti"] != x) {
    global[B + "_ti"] = x;
    var q = w.getElementsByClassName("page_guide_item")[x];
    }
    break
    }
    }
    }
    function setImgSrc(l) {
    var i = l.getElementsByTagName("img");
    var j = l.parentElement.parentElement.id;
    for (var g = 0; g < i.length; g++) {
    var h = i[g];
    if (h.src == "") {
    var k = h.offsetLeft - l.scrollLeft;
    if (k > -h.clientWidth && k < document.body.clientWidth) {
    h.src = h.getAttribute("img_src");
    h.onload = function() {
    this.style.backgroundImage = "url()";
    guideImgLoad(this)
    }
    }
    }
    }
    }
    function pageGuideMousedown(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    e.preventDefault();
    var f = d.parentElement.parentElement.id;
    global[f + "st"] = e.pageX;
    global[f + "fg"] = 1;
    clearInterval(global[f + "int"])
    }
    function pageGuideMousemove(d, e) {
    var f = d.parentElement.parentElement.id;
    if (!global[f + "fg"]) {
    return
    }
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    e.preventDefault();
    d.scrollLeft += global[f + "st"] - e.pageX;
    moveBalloon(d);
    global[f + "_sp"] = global[f + "st"] - e.pageX;
    if (global[f + "_sp"] < 5) {
    setImgSrc(d)
    }
    global[f + "st"] = e.pageX
    }
    function pageGuideMouseup(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    e.preventDefault();
    var f = d.parentElement.parentElement.id;
    global[f + "fg"] = 0;
    rollDelay(d, global[f + "_sp"], 0.03, f + "int")
    }
    function pageGuideMouseout(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    e.preventDefault();
    var f = d.parentElement.parentElement.id;
    global[f + "fg"] = 0
    }
    function pageGuideTouchstart(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    var f = d.parentElement.parentElement.id;
    global[f + "st"] = e.touches[0].pageX;
    clearInterval(global[f + "int"])
    }
    function pageGuideTouchmove(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    var f = d.parentElement.parentElement.id;
    global[f + "_sp"] = global[f + "st"] - e.touches[0].pageX;
    if (Math.abs(global[f + "_sp"]) >= 5) {
    e.preventDefault()
    }
    if (Math.abs(global[f + "_sp"]) < 10) {
    setImgSrc(d)
    }
    d.scrollLeft += global[f + "_sp"];
    moveBalloon(d);
    global[f + "st"] = e.touches[0].pageX
    }
    function pageGuideTouchend(d, e) {
    if (!e) {
    e = (window || global).event;
    if (!e) {
    return
    }
    }
    var f = d.parentElement.parentElement.id;
    rollDelay(d, global[f + "_sp"], 0.06, f + "int")
    }
    function guideImgLoad(b) {
    b = b.parentElement.parentElement.parentElement.parentElement;
    calcWidth(b);
    setProgress(b)
    }

    这个就是左右滑动的插件

    <div class="page_guide_container" onMouseDown="pageGuideMousedown(this,event)" onMouseMove="pageGuideMousemove(this,event)" onMouseUp="pageGuideMouseup(this,event)" onMouseOut="pageGuideMouseout(this,event)" ontouchstart="pageGuideTouchstart(this,event)" ontouchmove="pageGuideTouchmove(this,event)" ontouchend="pageGuideTouchend(this,event)">

    内容

    </div>

    要把要滑动的内容放在这个容器里面,然后自己设置宽度就行了,我是修改了插件,所以需要设置宽度

  • 相关阅读:
    Java运算符>、>>、>>>三者的区别
    深入浅析react native es6语法
    javascript基础学习(十五)
    javascript基础学习(十四)
    javascript基础学习(十三)
    javascript基础学习(十二)
    javascript基础学习(十一)
    javascript基础学习(十)
    javascript基础学习(九)
    javascript基础学习(八)
  • 原文地址:https://www.cnblogs.com/liubu/p/9012936.html
Copyright © 2011-2022 走看看