原生js实现拖拽效果

在这里插入图片描述

<!DOCTYPE html>  
<html>  
<head>  <style>  #mydiv {  width: 200px;  height: 200px;  background-color: red;  position: absolute;  cursor: move;  }  </style>  |
</head>  
<body>  <div id="mydiv">拖拽我</div>  <script>  var mydiv = document.getElementById('mydiv');  var x = 0, y = 0;  var limitX = window.innerWidth - 200; // 设置元素的最大宽度为屏幕宽度减去元素的宽度  var limitY = window.innerHeight - 200; // 设置元素的最大高度为屏幕高度减去元素的高度  mydiv.onmousedown = function(e) {  x = e.clientX - mydiv.getBoundingClientRect().left;  y = e.clientY - mydiv.getBoundingClientRect().top;  document.onmousemove = function(e) {  var newX = e.clientX - x;  var newY = e.clientY - y;  if (newX < 0) newX = 0; // 防止元素向左拖出屏幕外  if (newY < 0) newY = 0; // 防止元素向上拖出屏幕外  if (newX > limitX) newX = limitX; // 防止元素向右拖出屏幕外  if (newY > limitY) newY = limitY; // 防止元素向下拖出屏幕外  mydiv.style.left = newX + 'px';  mydiv.style.top = newY + 'px';  };  document.onmouseup = function() {  document.onmousemove = null; // 当鼠标松开时,移除鼠标移动事件  };  };  </script>  
</body>  
</html>
<template><div class="drag-box"><div id="dragContent"><div class="drag-home"><div class="drag-title" v-show="titleVisible"><br><br></div><div class="drag-switch"><div class="message"><div class="name">液压支架</div><div class="info">当前操作:前立柱升</div><div class="info">当前操作:前立柱升</div></div><div class="drag-button"><div class="menu"><el-button type="primary" round>采煤机</el-button><el-button type="success" round>液压知己</el-button><el-button type="info" round>总控开关</el-button></div><div class="stats"><el-button type="success" round v-for="(item, index) in 9" :key="index" style="width: 8rem;">按钮{{ item }}</el-button><i v-for="item in 9" :key="item"></i></div><div class="submit"><el-button type="primary" round>启动</el-button><el-button type="success" round>停止</el-button></div></div></div></div></div></div>
</template><script>
import { reactive, toRefs, onBeforeMount, onMounted, getCurrentInstance } from 'vue'export default {components: {},setup() {const state = reactive({rightDistance: '',leftWidth: '',maxWidth: '',titleVisible: false})onBeforeMount(() => {})onMounted(() => {var dragContent = document.getElementById('dragContent');var x = 0, y = 0;var limitX = window.innerWidth - 400; // 设置元素的最大宽度为屏幕宽度减去元素的宽度  state.maxWidth = limitXvar limitY = window.innerHeight - 600; // 设置元素的最大高度为屏幕高度减去元素的高度  var box = document.getElementById("dragContent")box.addEventListener('mouseover', () => {if (state.drightDistance == 0) {box.style.left = `${state.maxWidth / 10}rem`box.style.transitionDuration =  '1s'setTimeout(() => {state.titleVisible = false}, 300)} else {box.style.transitionDuration =  '0s'}})box.addEventListener('mouseout', () => {if (state.drightDistance == 0) {box.style.left = `${state.maxWidth / 10 + 40}rem`box.style.transitionDuration =  '1s'setTimeout(() => {state.titleVisible = true}, 300)} else {box.style.transitionDuration =  '0s'}});dragContent.onmousedown = (e) => {x = e.clientX - dragContent.getBoundingClientRect().left;y = e.clientY - dragContent.getBoundingClientRect().top;document.onmousemove = function (e) {var newX = e.clientX - x;var newY = e.clientY - y;if (newX < 0) newX = 0; // 防止元素向左拖出屏幕外  if (newY < 0) newY = 0; // 防止元素向上拖出屏幕外  if (newX > limitX) newX = limitX; // 防止元素向右拖出屏幕外  if (newY > limitY) newY = limitY; // 防止元素向下拖出屏幕外  dragContent.style.left = newX + 'px';dragContent.style.top = newY + 'px';state.leftWidth = newXstate.drightDistance = limitX - newX// console.log(state.leftWidth)};document.onmouseup = () => {document.onmousemove = null; // 当鼠标松开时,移除鼠标移动事件  console.log('当前坐标点', state.drightDistance)if (state.drightDistance == 0) {}}}})return {...toRefs(state),}}
}
</script>
<style lang="scss" scoped>
.drag-box {width: 100%;height: 100vh;overflow: hidden;position: absolute;
}#dragContent {width: 400px;height: 600px;position: absolute;right: 8rem;top: 50%;cursor: move;.drag-home {height: 100%;position: relative;background-color: #091659;border-radius: 3rem;.drag-title {position: absolute;left: -4rem;top: calc(50% - 8rem);font-size: 2rem;width: 4rem;height: 16rem;background: #0b133d;display: flex;align-items: center;justify-content: center;border-radius: 1rem 0 0 1rem}.drag-switch {height: 100%;position: relative;.message {text-align: left;padding: 2rem;.name {font-size: 2.5rem;margin: 0.5rem 0;}.info {font-size: 1.4rem;margin: 0.3rem 0;}}.drag-button {height: 80%;background: #22387b;position: absolute;bottom: 0;width: 90%;left: 5%;border-radius: 2rem;.menu {margin: 1rem 0;height: 10%;}.stats {height: 75%;/*background: pink;*/justify-content: space-around;align-content: start;display: flex;flex-wrap: wrap;.el-button {margin: 1rem 0;}.el-button+.el-button {margin-left: unset;}i {margin: 1rem 0;width: 8rem;}}.submit {height: 15%;}}}}
}
</style>

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

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

相关文章

什么是信噪比

大家好&#xff0c;今天给大家介绍什么是信噪比&#xff0c;文章末尾附有分享大家一个资料包&#xff0c;差不多150多G。里面学习内容、面经、项目都比较新也比较全&#xff01;可进群免费领取。 “信噪比”是电子技术中经常用到的一个词组&#xff0c;知道它的确切含义有一定意…

vivado18.3和modelsim关联

版本关系 首先明确Modelsim与Vivado的联合仿真需要版本号相匹配&#xff0c;Xilinx官方文档UG973中给出了所有版本的Vivado兼容Modelsim的版本情况 Vivado版本号Modelsim版本号Vivado Design Suite 2022.2Mentor Graphics ModelSim DE (2022.2)Vivado Design Suite 2022.1Men…

【前端性能优化】如何取消http请求

文章目录 需要取消http请求的3种经典场景原生XMLHttpRequest取消http请求fetch取消http请求axios取消http请求哪些情况需要取消HTTP请求取消http请求能带来哪些性能提升 需要取消http请求的3种经典场景 场景一&#xff1a;有一个实时搜索功能&#xff0c;每当用户输入内容改变的…

python爬虫小练习——爬取豆瓣电影top250

爬取豆瓣电影top250 需求分析 将爬取的数据导入到表格中&#xff0c;方便人为查看。 实现方法 三大功能 1&#xff0c;下载所有网页内容。 2&#xff0c;处理网页中的内容提取自己想要的数据 3&#xff0c;导入到表格中 分析网站结构需要提取的内容 代码 import requests…

【昕宝爸爸小模块】线程的几种状态,状态之间怎样流转

➡️博客首页 https://blog.csdn.net/Java_Yangxiaoyuan 欢迎优秀的你&#x1f44d;点赞、&#x1f5c2;️收藏、加❤️关注哦。 本文章CSDN首发&#xff0c;欢迎转载&#xff0c;要注明出处哦&#xff01; 先感谢优秀的你能认真的看完本文&…

vue中动态给不同表单赋值

这里的业务是通过关联的 id 发送不同的请求获取表单的数据&#xff0c;然后回显到页面中&#xff0c;整个的页面是由多个表单拼接起来的 点击下一步的时候&#xff0c;获取下一个表单的内容。 // 查询getForm(index) {switch (index) {case 0:this.getFromInfo("inputFor…

图鸟Vue3版本部署

无法将“pnpm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。 分析原因 这个错误信息表明在 VS Code 终端中尝试运行 pnpm install&#xff0c;但系统无法识别 pnpm 命令。这通常表示 pnpm 这个工具没有被正确安装&#xff0c;或者它的可执行文件所在的路径没有被正确…

故障诊断全家桶,看这一篇就够了,精品力荐!

本期推出故障诊断全家桶&#xff0c;包含传统的分析时频诊断方法&#xff0c;依靠数据分解方法的诊断方法&#xff0c;依靠机器学习的诊断方法。还包含了6种适应度函数随意切换的VMD优化方法&#xff0c;16种数据分解方法&#xff0c;包络谱&#xff0c;包络熵等代码。以及作者…

剪映国际版,免费无限制使用

随着抖音的爆火短视频的崛起&#xff0c;相信每一个人都感受到了短视频快节奏下的生活洪流。 现如今每个人都能成为自己生活的记录者&#xff0c;每一个人都有掌握着剪辑的基本技能。而剪映就是很多人都会使用的剪辑软件。 相对于PR、AE等剪辑软件来说&#xff0c;作为一款国…

【金猿CIO展】步长制药信息化管理与建设中心总经理束炼:IT部门既要懂技术,也要懂业务...

‍ 束炼 本文由步长制药信息化管理与建设中心总经理束炼撰写并投递参与“数据猿年度金猿策划活动——2023大数据产业年度优秀CIO榜单及奖项”评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 随着数字化转型的浪潮席卷各行各业&#xff0c;中国数字经济已进入快速发展阶…

Mybatis 常用条件语句,大于小于、if、for、模糊搜索、case when、choose

大于小于 方法1&#xff1a; > 大于 &#xff0c; < 小于 <if test"startTime ! null ">and a.create_time > #{startTime} </if> <if test"endTime ! null ">and a.create_time < #{endTime} </if> 方法2(建议写这…

PLECS如何下载第三方库并导入MOSFET 的xml文件,xml库路径添加方法及相关问题

1. 首先xml库的下载&#xff0c;PLECS提供了一个跳转的链接。 https://www.plexim.com/download/thermal_models 2. 下载一个库&#xff08;以最后一个Wolfspeed为例&#xff0c;属于CREE的SiC MOSFET&#xff09; 下载这个就行&#xff0c;都包含了。不信自己可以试试再下载…

响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 例4-1 表单

代码 <!doctype html> <html> <head> <meta charset"utf-8"> <title>表单</title> </head><body> <!--<form action"URL地址" method"提交方式" name"表单名称" /*编码“多部…

【QML COOK】- 008-自定义属性

前面介绍了用C定义QML类型&#xff0c;通常在使用Qt Quick开发项目时&#xff0c;C定义后端数据类型&#xff0c;前端则完全使用QML实现。而QML类型或Qt Quick中的类型时不免需要为对象增加一些属性&#xff0c;本篇就来介绍如何自定义属性。 1. 创建项目&#xff0c;并编辑Ma…

NVIDIA-SMI has failed because it couldn‘t communicate with the NVIDIA driver

安装显卡驱动 https://fakerth.blog.csdn.net/article/details/134659236 NVIDIA-SMI has failed because it couldn‘t communicate with the NVIDIA driver 电脑打开分辨率直接变了&#xff0c;运行nvidia-smi报错&#xff0c;当时我就在爆发的边缘了&#xff0c;想着大好…

C语言数据结构(1)复杂度(大o阶)

欢迎来到博主的专栏——C语言与数据结构 博主ID——代码小豪 文章目录 如何判断代码的好坏时间复杂度什么是时间复杂度如何计算时间复杂度 空间复杂度 如何判断代码的好坏 实现相同作用的不同代码&#xff0c;如何分辨这些代码的优劣之处呢&#xff1f; 有人说了&#xff0c…

原子类-入门介绍和分类说明、基本类型原子类

Atomic翻译成中文是原子的意思。在化学上,我们知道原子是构成一般物质的最小单位,在化学 反应中是不可分割的。在我们这里Atomic是指一个操作是不可中断的。即使是在多个线程一起执 行的时候,一个操作一旦开始,就不会被其他线程干扰。 基本类型原子类 AtomicInteger:整…

在illustrator中按大小尺寸选择物体 <脚本 018>

在Illustrator中我们可以依据对象的属性 如:填充颜色、描边颜色或描边宽度来选择相同属性的对象,但是Illustrator中没有根据不同大小尺寸来选择对象的功能,下面介绍的就是根据大小尺寸选择对象的脚本。 1、下面是当前画板中的所有对象,我们想把一些在尺寸小一些的方形物体…

金融帝国实验室(Capitalism Lab)V10版本游戏平衡性优化与改进

即将推出的V10版本中的各种游戏平衡性优化与改进&#xff1a; ————————————— 一、当玩家被提议收购一家即将破产的公司时&#xff0c;显示商业秘密。 当一家公司濒临破产&#xff0c;玩家被提议收购该公司时&#xff0c;如果玩家有兴趣评估该公司&#xff0c;则无…

datavrap-各种各样的条形图(含详细操作步骤)

静态条形图&#xff1a;正确设置数据即可&#xff0c;导出的图形不会随着时间变化 最普通的静态条形图 黑色系风格的静态条形图 动态条形图&#xff1a;导出的图形会随着时间变化 普通的动态条形图 带数字滚动效果的动态条形图 简单的Top排行榜动态条形图 格式更丰富的Top排行榜…