前端使用Ant Design中的Modal框实现长按顶部拖动弹框需求

需求:需要Ant Design中的一个Modal弹框,并且可以让用户按住顶部实现拖动操作

实现:在Ant Design的Modal框的基础上,在title中添加一个onMouseDown去记录拖拽的坐标,然后将其赋值给Modal的style属性

代码部分:

import { PureComponent } from 'react';
import { Modal } from 'antd';
class ZRJModal extends PureComponent {constructor(props) {super(props)//Modal 的初始值this.state = {styleTop: 100,styleLeft: 0,}}//计算是否超出屏幕;超出后inWindow = (left:any, top:any, startPosX:any, startPosY:any) => {let H = document.body.clientHeight;let W = document.body.clientWidth;if ((left < 20 && startPosX > left) || (left > W - 20 && startPosX < left) ||(top < 20 && startPosY > top) || ((top > H - 20 && startPosY < top))) {document.body.onmousemove = null;document.body.onmouseup = null;return false;}return true;}onMouseDown = (e:any) => {e.preventDefault();let startPosX = e.clientX;let startPosY = e.clientY;const { styleLeft, styleTop } = this.state;document.body.onmousemove = e => {let left = e.clientX - startPosX + styleLeft;let top = e.clientY - startPosY + styleTop;if (this.inWindow(e.clientX, e.clientY, startPosX, startPosY)) {this.setState({styleLeft: left,styleTop: top,})}};//鼠标放开时去掉移动事件document.body.onmouseup = function () {document.body.onmousemove = null;};};render() {const { styleLeft, styleTop } = this.state;const style = { left: styleLeft, top: styleTop }return <Modaltitle={<div style={{width:'100%',cursor:'move'}} onMouseDown={this.onMouseDown}>孜然卷弹框</div>}style={style}visible={this.state.RGZJvis}onOk={this.RGZJOK}okText={'保存'}width={650}onCancel={this.RGZJhandleCancel}>孜然卷内容</Modal >}
}
export default ZRJModal

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/732078.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Django中执行update更新时auto_now问题

一、问题说明 在我们给模型的时间字段updated_at字段添加auto_nowTrue之后&#xff0c;原则上来说在更新数据是会自动修改更新时间。 但是当我们使用在代码中使用ORM中的filter(xxxxxx).update(xxxxxx)时发现&#xff0c;更新时间字段并没有完成更新。 而如果使用obj.save()…

【JavaEE进阶】 @Transactional详解

文章目录 &#x1f343;前言&#x1f332;rollbackFor&#xff08;异常回滚属性&#xff09;&#x1f384;事务隔离级别&#x1f6a9;MySQL事务隔离级别&#x1f6a9;Spring事务隔离级别 &#x1f38b;Spring事务传播机制&#x1f6a9;什么是事务传播机制&#x1f6a9;事务有哪…

Android 11 系统开发增加低电量弹窗提示 手机 平板 车载 TV 投影 通用

1、PowerUI是系统中控制电量提示的模块&#xff0c;低电量提醒、低电量关机提醒、高温关机提醒、省电模式都在其中实现 SystemUIService 中启动PowerUI public class SystemUIService extends Service {Overridepublic void onCreate() {super.onCreate();((SystemUIApplicat…

【SpringMVC】RESTFul风格设计和实战 第三期

文章目录 概述一、 RESTFul风格简介二、 RESTFul风格特点三、 RESTFul风格设计规范3.1 HTTP协议请求方式要求3.2 URL路径风格要求 实战一、需求分析二、RESTFul风格接口设计三、后台接口实现总结模糊查询 有范围 返回多数据用户 添加 与 更新 请求参数接收数据显示用户详情/删除…

进腾讯工作一个月,我想辞职了......

前几天&#xff0c;我在网上看到一个微博。 一个应届的校招生&#xff0c;目前入职腾讯&#xff0c;工作了一个月。这一个月给他的感受是大量的写测试用例&#xff0c;自己写测试用例的能力熟练了不少&#xff0c;测试技能倒是没有多大的提高&#xff0c;真正需要技术的工作却…

软考71-上午题-【面向对象技术2-UML】-UML中的图2

一、用例图 上午题&#xff0c;考的少&#xff1b;下午题&#xff0c;考的多。 1-1、用例图的定义 用例图展现了一组用例、参与者以及它们之间的关系。 用例图用于对系统的静态用例图进行建模。 可以用下列两种方式来使用用例图&#xff1a; 1、对系统的语境建模&#xff1b…

【java 分页工具类】分页工具PageBean(149)

分页工具类&#xff1a; package com.itheima3;import java.util.ArrayList; import java.util.List;public class PageBean<T> {private int pageSize; // 每页记录数private int pageNo; // 当前页private int totalPages; // 总页数private int totalRecords; // 总记…

ChatGPT 升级出现「我们未能验证您的支付方式/we are unable to authenticate」怎么办?

ChatGPT 升级出现「我们未能验证您的支付方式/we are unable to authenticate」怎么办&#xff1f; 在订阅 ChatGPT Plus 时&#xff0c;有时候会出现以下报错 &#xff1a; We are unable to authenticate your payment method. 我们未能验证您的支付方式。 出现 unable to a…

低密度奇偶校验码LDPC(十)——LDPC码的密度进化

一、密度进化的概念 二、规则LDPC码的密度进化算法(SPA算法) 算法变量表 VN更新的密度进化 CN更新的密度进化 算法总结 程序仿真 参考文献 [1] 白宝明 孙韶辉 王加庆. 5G 移动通信中的信道编码[M]. 北京: 电子工业出版社, 2018. [2] William E. Ryan, Shu Lin. Channel Co…

优牛企讯司法涉诉维度全解析,了解这些小白也可以变专家!

在商业的海洋中&#xff0c;信息的掌握就如同舵手对风向的了解。每一条信息都可能成为引领航船前行的关键&#xff0c;尤其是在法律风险的管理上&#xff0c;准确而及时的信息更是企业稳健航行的保障。 优牛企讯&#xff0c;一款专业的企业司法涉诉监控查询工具&#xff0c;它…

SpringMVC03、HelloSpring

3、HelloSpring 3.1、配置版 新建一个Moudle &#xff0c; springmvc-02-hello &#xff0c; 添加web的支持&#xff01; 确定导入了SpringMVC 的依赖&#xff01; 配置web.xml &#xff0c; 注册DispatcherServlet <?xml version"1.0" encoding"UTF-8…

微调模型(Machine Learning 研习之十二)

现在正处于百模乱战的时期&#xff0c;对于模型微调&#xff0c;想必您是有所了解了&#xff0c;毕竟国外的大语言模型一开源&#xff0c;国内便纷纷基于该模型进行微调&#xff0c;从而开始宣称领先于某某、超越了谁。可到头来&#xff0c;却让人发现他们套壳了国外大语言模型…

【第58例】IPD体系进阶:战略的五个核心要素

目录 1. 内容简介 2. 计划与行动 3. 计划层面 CSDN学院 作者简介 1. 内容简介 今天继续来更新 IPD 体系进阶专栏:战

Linux Ubuntu 部署SVN

最近需要在ubuntu server上部署一个svn&#xff0c;记录 不需要特定版本 如果不需要特定版本&#xff0c;这样安装就是最简单的 sudo apt update然后开始安装 sudo apt install subversion等到安装完成之后执行查看版本命令&#xff0c;如果正常输出那就没问题了 svnadmin …

C++默认参数详解

目录 缺省参数/默认参数概念&#xff1a; 缺省参数的应用场景&#xff1a; 函数定义定义分离时的默认参数&#xff1a; 简单的编译链接&#xff1a; 缺省参数/默认参数概念&#xff1a; 缺省参数/默认参数&#xff1a;通俗点讲就是形参给的那个某个值 func(int a 0); //例…

uniapp 使用定时器和取消定时器

1. uniapp 使用定时器和清除定时器 1.1. 定义一个timer data(){return{timer: null} }1.2. 设置定时器 //选择适合需求的定时器 this.timer setTimeout( () > {// 这里添加您的逻辑 }, 1000) this.timer setInterval( () > {// 同上 }, 1000)1.3. 清除定时器 这…

差分算法:空调-USACO 2021 December Contest Bronze

4262. 空调 - AcWing题库 Farmer John 的 N 头奶牛对他们牛棚的室温非常挑剔。 有些奶牛喜欢温度低一些&#xff0c;而有些奶牛则喜欢温度高一些。 Farmer John 的牛棚包含一排 N 个牛栏&#xff0c;编号为 1…N&#xff0c;每个牛栏里有一头牛。 第 i 头奶牛希望她的牛栏中的温…

汽车协议学习

ⅠOBD 1.OBD接口 OBD有16个引脚&#xff0c;每个引脚的电压不同&#xff08;可以对应不同的协议&#xff09; 车端&#xff1a; 16- 9 (短一点点的) 8-1 &#xff08;长一点的&#xff09; 2.基于OBDⅡ的通信协议 CAN &#xff08;ISO-15765&am…

windows将bat脚本设置为开机自启动

windows将bat脚本设置为开机自启动 使用场景&#xff1a;需要在windows开机启动时直接运行一个bat脚本&#xff0c;通过这个脚本调用写好的python之类的管理工具。 步骤&#xff1a; 1、按下Win R快捷键打开“运行”对话框 2、输入shell:startup&#xff0c;然后按下回车键 3、…

Python-Flask 快学

flask是Python的一个轻型Web框架. 使用pycharm自动创建项目,也可以手动创建,以下是目录的结构: ├── app.py├── static└── templates 一、创建一个简单应用 from flask import Flaskapp Flask(__name__)app.route(/) def hello_world():return "hello world &…