广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React实现双滑块交叉滑动
  • 616
分享到

React实现双滑块交叉滑动

2024-04-02 19:04:59 616人浏览 薄情痞子
摘要

本文实例为大家分享了React实现双滑块交叉滑动的具体代码,供大家参考,具体内容如下 html代码: <body> <div id="root">

本文实例为大家分享了React实现双滑块交叉滑动的具体代码,供大家参考,具体内容如下

html代码:


<body>
    <div id="root"></div>
</body>

script代码:


<script type="text/babel">
    const root = document.querySelector('#root')
    class Comp extends React.Component {
        constructor(...args) {
            super(...args)
        }
        fn(ev) {
            // 获取鼠标点击的距离
            this.pageX = ev.changedTouches[0].pageX - ev.target.offsetLeft
            // 获取父级
            this.parentWidth = ev.target.parentnode.offsetWidth - ev.target.offsetWidth
            // 获取父级
            this.parent = ev.target.parentNode
            // 获取线条
            this.line = this.parent.children[2]
 
 
            // 获取左边小球
            this.oBall = this.parent.children[0]
            // 右边小球
            this.oBallTwo = this.parent.children[1]
 
            document.ontouchmove = this.fnMove.bind(this)
            document.ontouchend = this.fnEnd
        }
        fnMove(ev) {
            // 盒子偏移量 
            this.X = ev.changedTouches[0].pageX - this.pageX
            // 判断偏移量不能大于父盒子的宽
            if (this.X >= this.parentWidth) {
                this.X = this.parentWidth
            }
            // 判断不能小于0
            if (this.X <= 0) {
                this.X = 0
            }
            // 计算线条的宽  小球交互  计算绝对值就是线条的宽
            this.lineWidth = Math.abs(this.oBallTwo.offsetLeft - this.oBall.offsetLeft)
            // 线条的宽度
            this.line.style.width = this.lineWidth + 'px'
            // 小球距离左边的距离
            ev.target.style.left = this.X + 'px'
            // 判断右边小球的offsetLeft减掉左边小球的offsetLeft值 如果小于0就是 右边小球距离左边最近 取出它的offsetLeft值就是线条距离左边的值
            if(this.oBallTwo.offsetLeft-this.oBall.offsetLeft<0){
                this.line.style.left=this.oBallTwo.offsetLeft+'px'
            }else{
                this.line.style.left=this.oBall.offsetLeft+'px'
            }
        }
        fnEnd() {
            document.ontouchmove = null
            document.ontouchend = null
        }
        render() {
            return (<div className='box'>
                <div className='ball' onTouchStart={this.fn.bind(this)}></div>
                <div className='ball ac' onTouchStart={this.fn.bind(this)}></div>
                <div className='line'></div>
                <div className='lineT'></div>
            </div>)
        }
    }
    ReactDOM.render(<Comp />, root)
 
</script>

CSS样式:


<style>
        body {
            margin: 0;
            padding: 0;
        }
 
        .box {
            width: 500px;
            height: 40px;
            background: #999;
            position: relative;
            margin: auto;
            margin-top: 100px;
        }
 
        .ball {
            width: 40px;
            height: 40px;
            background: red;
            position: absolute;
            border-radius: 50%;
            z-index: 10;
        }
 
        .ball.ac {
            background: #0f0;
            right: 0;
        }
 
        .line {
            height: 5px;
            width: 500px;
            background: rgb(200, 110, 7);
            position: absolute;
            top: 50%;
            left: 0;
            transfORM: translate(0, -50%);
            z-index: 5;
        }
 
        .lineT {
            height: 5px;
            width: 500px;
            background: #fff;
            position: absolute;
            top: 50%;
            left: 0;
            transform: translate(0, -50%);
        }
</style>

第二种方式:点击链接查看第二种

Vue实现小球滑动交叉效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: React实现双滑块交叉滑动

本文链接: https://www.lsjlt.com/news/135222.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • React实现双滑块交叉滑动
    本文实例为大家分享了React实现双滑块交叉滑动的具体代码,供大家参考,具体内容如下 html代码: <body> <div id="root">...
    99+
    2022-11-12
  • vue实现小球滑动交叉效果
    本文实例为大家分享了vue实现小球滑动交叉效果的具体代码,供大家参考,具体内容如下 废话不多说 直接上代码! <template> <div class="...
    99+
    2022-11-12
  • react怎么实现滑动
    本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。react怎么实现滑动?react 实现左右滑动效果React 中滑动手势的实现最近做了一点关于react在移动端滑动翻页的功能。开始搜索了一下,发现居然...
    99+
    2023-05-14
    滑动 React
  • react如何实现滑动效果
    今天小编给大家分享一下react如何实现滑动效果的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。react实现滑动的方法:1、...
    99+
    2023-07-04
  • Vue实现双向滑动输入条
    本文实例为大家分享了Vue实现双向滑动输入条的具体代码,供大家参考,具体内容如下 效果图如下: 组件支持传入最小值(min)最大值(max)的范围,并可设置初始最小值(initial...
    99+
    2022-11-13
  • vue3实现移动端滑动模块
    本文实例为大家分享了vue3实现移动端滑动模块的具体代码,供大家参考,具体内容如下 需要实现的需求如下 直接上代码 HTML: <div class="container" ...
    99+
    2022-11-13
  • vue实现移动滑块验证
    本文实例为大家分享了vue实现移动滑块验证的具体代码,供大家参考,具体内容如下 记录一下今天的学习内容 <div class="solidBox" :class="{'so...
    99+
    2022-11-13
  • js实现拖动滑块效果
    本文实例为大家分享了js如何拖动滑块的具体代码,供大家参考,具体内容如下 实现拖动滑块,先分析,滑块可以拖动应该改变滑块在页面中的坐标,那就采用定位拿到元素的 top 和 left ...
    99+
    2022-11-12
  • JS实现拖动滑块验证
    使用这种验证方法的目的:证明当前的用户不是机器人~防止恶意操作。 实现思路: 1、获取silde滑块(获取元素) 2、为元素注册事件———鼠标点击...
    99+
    2022-11-13
  • 小程序实现滑动块效果
    本文实例为大家分享了小程序实现滑动块效果的具体代码,供大家参考,具体内容如下 当你在复制的时候 一定要 把js 逻辑的 list 数据更改就行了 小程序的css样式 .box {...
    99+
    2022-11-12
  • Vue怎么实现双向滑动输入条
    这篇“Vue怎么实现双向滑动输入条”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue怎么实现双向滑动输入条”文章吧。效果图...
    99+
    2023-06-29
  • ScrollView与SeekBar绑定如何实现滑动时出现小滑块效果
    这篇文章主要介绍ScrollView与SeekBar绑定如何实现滑动时出现小滑块效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!重写SeekBarpublic class VerticalSee...
    99+
    2023-05-30
    scrollview seekbar 滑动
  • Flutter实现滑动块验证码功能
    Flutter实现滑动块验证码功能,供大家参考,具体内容如下 本文实现的是一个用于登录时,向右滑动滑动块到最右边完成验证的一个功能。当滑动未到最右边时,滑动块回弹回左边起始位置。 ...
    99+
    2022-11-13
  • Android 实现单指滑动、双指缩放照片
    一、前景提示 最近接到一个查看大图的需求,现在图片展示还不够大,要求还要能缩小能放大还能保存照片。直接开始Google实现方式。 二、实现功能 根据查询到的结果分为两种,一个是使用手势监听来实现,第二...
    99+
    2023-08-31
    android 自定义View
  • Angular.js如何通过自定义指令directive实现滑块滑动效果
    这篇文章主要介绍Angular.js如何通过自定义指令directive实现滑块滑动效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!方法如下1.下面是我html部分代码,detai...
    99+
    2022-10-19
  • react card slider实现滑动卡片教程示例
    目录效果实现card-slider.tsxcard-item.tsxApp.tsx效果 实现 通过zIndex控制层级,opacity控制透明度,transform 控制卡片缩放程...
    99+
    2022-11-13
  • vue实现移动端原生小球滑块
    本文实例为大家分享了vue实现移动端原生小球滑块的具体代码,供大家参考,具体内容如下 效果 用到的一些事件 阻止默认事件:ev.preventDefault && ...
    99+
    2022-11-13
  • Python+Selenium实现网站滑块拖动操作
    实现效果 示例代码 import time from selenium import webdriver from selenium.webdriver import Action...
    99+
    2022-11-11
  • Flutter怎么实现滑动块验证码功能
    这篇文章主要介绍“Flutter怎么实现滑动块验证码功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter怎么实现滑动块验证码功能”文章能帮助大家解决问题。本文实现的是一个用于登录时,向右...
    99+
    2023-06-29
  • Android开发双向滑动选择器范围SeekBar实现
    目录一、概述二、实现2.1 首先看我们自定义View的全部代码2.2 实现流程初始化计算宽高onDraw 绘制进度条事件监听三、使用 布局文件布局文件(有刻度线)布局文件(无刻...
    99+
    2022-06-09
    选择器 选择 seekbar android开发 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作