基于vue自制简单range的代码

不言
Lepaskan: 2018-09-11 15:27:25
asal
1520 orang telah melayarinya

本篇文章给大家带来的内容是关于基于vue实现简单range的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

废话不多说先上成果图

2340175370-5b96f78f19eda_articlex.gif

实现思路

主要分界面与逻辑两大块

界面分为5个部分

  • 左滑块长度

  • 左内容位置

  • 中间长度

  • 右滑块长度

  • 右内容位置

逻辑

  • touch3个事件

  • 各滑块长度及位置计算

  • 选中时变色

具体实现步骤
  1. 首先我们明白整个容器的长度是不变的等于左边+中间+右边所以我们可以通过先获取总的容器的宽度并用变量进行保存,这里我用的就是屏幕的宽度。

this.rangeWidth = document.body.clientWidth
Salin selepas log masuk
  1. 添加vue的三种touch事件

@touchstart.stop.prevent="leftTextTouchStart" //按下 
@touchmove.stop.prevent="leftTextTouchMove" //滑动 
@touchend.stop.prevent="leftTextTouchEnd"  //松开//右滑块,同上 
@touchstart.stop.prevent="rightTextTouchStart" 
@touchmove.stop.prevent="rightTextTouchMove" 
@touchend.stop.prevent="rightTextTouchEnd"
Salin selepas log masuk
  1. 使用类绑定的方式,在touchStart事件触发的方式,修改点击的滑块的样式,在松开时触发touchend事件,恢复原来的样式

//滑动事件方法
leftTextTouchStart() {
    this.leftClick = true;
}, 
leftTextTouchEnd() {
    this.leftClick = false;
},
//类样式绑定
:class="{check_text_p:leftClick}"
Salin selepas log masuk
  1. 滑动时三大块核心宽度及位置的计算,因为滑动中坐标轴是实时变化,这里我们使用vue的计算属性进行操作

rangeWidth //整个容器的宽度
leftWidth //左边滑动的距离,通过滑动事件定义
rightWidth //右边滑动的距离,通过滑动事件定义
width() {
    return Math.min(Math.max(0, this.rangeWidth - this.leftWidth - this.rightWidth), this.rangeWidth)//内容宽度应等于总宽度减去左右两边,且大于等于0小于等于总宽度
}
left() {    
    return Math.max(this.leftWidth, 0)//防止左滑出界面
}
right() {
    if (this.left + this.rightWidth <= this.rangeWidth) return Math.max(this.rightWidth - 0.5, 0)//防止右滑出界面
}
Salin selepas log masuk
  1. 滑动事件中,界面变化及左右两边滑动距离的记录

leftTextTouchMove(e) {
    let touch = e.changedTouches[0];
    let clientX = touch.clientX;//获取滑动事件的横坐标值    
    if (clientX >= 0) {//只检测滑块在坐标值在屏幕内       
        if (this.left + this.right <= this.rangeWidth) {//防止左右滑块位置倒置            
            this.leftWidth = clientX;//左滑块距离等于x坐标            //界面操作            
            $(&#39;#nowRange&#39;).css({&#39;left&#39;: this.left, &#39;width&#39;: this.width});
            $(&#39;#leftText&#39;).css({&#39;left&#39;: this.left});
            $(&#39;#leftImg&#39;).css({&#39;left&#39;: this.left});      
        }   
    }
}
rightTextTouchMove(e) {
    let touch = e.changedTouches[0];
    let clientX = touch.clientX;//获取滑动事件的横坐标值    
    if (clientX <= this.rangeWidth) {//只检测滑块在坐标值在屏幕内        
        this.rightWidth = this.rangeWidth - clientX;//右边滑块距离等于总长度减去滑动横坐标       
        if (this.left + this.right <= this.rangeWidth) {//防止左右滑块位置倒置            //界面变化           
            $(&#39;#nowRange&#39;).css({&#39;width&#39;: this.width});
            $(&#39;#rightText&#39;).css({&#39;right&#39;: this.right});
            $(&#39;#rightImg&#39;).css({&#39;right&#39;: this.right});
        }    
    }
},
Salin selepas log masuk

6.文本内容通过计算值便可实现

leftText() {
    let num = parseInt(this.left / this.rangeWidth * 100);
    if (num === 0 || isNaN(num)) return &#39;不限&#39;;    
    return num + &#39;k&#39;;
}
rightText() {
    if (this.rangeWidth === 0) return &#39;不限&#39;;    
    let num = parseInt((this.rangeWidth - this.right) / this.rangeWidth * 100);
    if (num >= 0) {
        if (num === 100) return '不限';
        return num + 'k';    
    }
}
Salin selepas log masuk

核心代码就这些了。

相关推荐:

基于Vue的简单的单页面应用的实现_html/css_WEB-ITnose

使用vue自动化表单(附代码)

Atas ialah kandungan terperinci 基于vue自制简单range的代码. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan