为什么不能移动文档内容

来源:3-4 拖动滑块内容滚动的实现

qq_nn_19

2017-11-09 21:32

if(sliderEl){

       var doc = this.$doc,//获取文本对象
       dragStartPagePosition,//鼠标起始位置
       dragStartScrollPosition,//元素内容的起始位置
       dragContBarRate;//???
       function mousemoveHandler() {
           e.preventDefault();
           console.log("mousemove");
           if(dragStartPagePosition == null){
               return ;
           }
           self.scrollTo(dragStartScrollPosition + (e.pageY-dragStartPagePosition)*0.5);
       }
       slider.on("mousedown",function (e) {
           e.preventDefault();//去除文本对象默认功能
           console.log("mousedown");
           dragStartPagePosition = e.pageY;//获取鼠标距离文档顶部的距离
           alert('1'+self.$cont[0].scrollTop);
           dragStartScrollPosition = self.$cont[0].scrollTop;//滚动区内容对象的起始数据
           alert('2');
           alert("dragStartPagePosition"+dragStartPagePosition+"dragStartScrollPosition"+dragStartScrollPosition)
           doc.on("mousemove.scroll", mousemoveHandler())
               .on("mouseup.scroll",function (e) {
                   console.log("mouseup");
                   doc.off(".scroll")
                   });
       });
   }
   return self;
},
//内容可滚动的高度
getMaxScrollPosition:function () {
    var self = this;
    //获取滚动条内容高度:可视区和元素内容高度的最大值
    return Math.max(self.$cont.height(),self.$cont[0].scrollHeight)-self.$cont.height();
    //内容可滚动的距离为:文本内容高度-可视区内容高度,当文本内容高度小于可视区时可移动距离为0
},
//滑块可移动的高度
getMaxSliderPosition:function () {
   var self = this;
   return self.$bar.height() - self.$slider.height();//可移动的高度就是滚动条的高度-滑块的高度
},
//滚动函数
scrollTo:function (positionVal) {
   var self = this;
   self.$cont.scrollTop(positionVal);//设置每个匹配元素的垂直滚动条位置,元素内容超出上边界的像素
}

写回答 关注

0回答

还没有人回答问题,可以看看其他问题

jQuery实现自定义滚动条

来一次jQuery封装之旅,本教程带你深入理解滚轮事件交互

39577 学习 · 76 问题

查看课程

相似问题