电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JavaScript實現拖拽和縮放效果

瀏覽:127日期:2023-06-17 16:16:59

本文實例為大家分享了JavaScript實現拖拽和縮放效果的具體代碼,供大家參考,具體內容如下

<!DOCTYPE html><html><head> <meta charset='utf-8' /> <meta http-equiv='X-UA-Compatible' content='IE=edge'> <title>拖拽縮放</title> <meta name='viewport' content='width=device-width, initial-scale=1'></head><style> * { margin: 0; padding: 0 } #box { width: 100%; height: 100%; position: relative; background: #4bb0bb } #drag { width: 200px; height: 200px; position: relative; background: #691fff; cursor: move; } #scale { width: 20px; height: 20px; position: absolute; background: #ffa500; cursor: se-resize; right: 0; bottom: 0; overflow: hidden; }</style><body> <div id='box'> <div id='drag'> <div id='scale'></div> </div> </div></body><script> window.onload = function () { var box = document.getElementById('box') var drag = document.getElementById('drag') var scale = document.getElementById('scale') // mousedown mousemove mouseup dragTool(drag) scaleTool(drag, scale, box) // 拖拽方法 function dragTool(node) { node.onmousedown = function (ev) {// 瀏覽器兼容處理var e = ev || window.event;// 鼠標按下記錄相對位置// 水平方向都距離 = 當前鼠標左邊的距離 - 被拖拽元素距離左邊的距離var offsetX = e.clientX - node.offsetLeft;// 垂直方向都距離 = 當前鼠標都上邊的距離 - 被拖拽元素距離距離的距離var offsetY = e.clientY - node.offsetTop;// 鼠標移動和被拖拽的元素是相對的 這里是鼠標拖拽的物體在整個頁面上移動 所以// move加在document上document.onmousemove = function (ev) { // 當前鼠標的事件對象 var e = ev || window.event; // 定義 currentLeft = 當前鼠標位置 - 距離左邊的距離 var currentLeft = e.clientX - offsetX; // 定義 currentTop = 當前鼠標上邊位置 - 距離上邊的距離 var currentTop = e.clientY - offsetY // 限制左出界 最左是 0 if (currentLeft <= 0) { currentLeft = 0; } // 當前窗口的寬 瀏覽器兼容 var windowWidth = document.documentElement.clientWidth || document.body.clientWidth; // 限制右邊出界 如果大于當前窗口的寬 那么就讓它等于當前窗口的寬減去當前元素的offsetWidth 也就是留在原地 if (currentLeft >= windowWidth - node.offsetWidth) { currentLeft = windowWidth - node.offsetWidth; } // 設置上出界 最上邊是 0 if (currentTop <= 0) { currentTop = 0; } // 當前窗口的高 瀏覽器兼容 var windowHeight = document.documentElement.clientHeight || document.body.clientHeight; // 限制下邊出界 如果大于當前窗口的高 減去 本身的高 那么就讓它等于 當前窗口的高減去本身的高 if (currentTop >= windowHeight - node.offsetHeight) { currentTop = windowHeight - node.offsetHeight; } // 當前被拖拽元素的 left 值 等于上面計算出的 currentLeft node.style.left = currentLeft + ’px’; // 當前被拖拽元素的 top 值 等于上面計算出的 currentTop node.style.top = currentTop + ’px’;} } // 鼠標彈起取消拖拽 這里添加到 node 元素對象也可以的 document.onmouseup = function () {document.onmousemove = null; } } // 縮放 function scaleTool(drag, scale, box) { scale.onmousedown = function (e) {//阻止冒泡 避免縮放觸發移動事件e.stopPropagation()// 取消事件的默認動作e.preventDefault()// 定義positionvar position = { ’w’: drag.offsetWidth, // 被縮放元素的offsetWidth ’h’: drag.offsetHeight, // 被縮放元素的offsetHeight ’x’: e.clientX, // 當前窗口鼠標指針的水平坐標 ’y’: e.clientY, // 當前窗口鼠標指針的垂直坐標}drag.onmousemove = function (ev) { ev.preventDefault() // 設置最大縮放為30*30 Math.max取最大值 var w = Math.max(30, ev.clientX - position.x + position.w) var h = Math.max(30, ev.clientY - position.y + position.h) // 設置最大的寬高 w = w >= box.offsetWidth - drag.offsetLeft ? box.offsetWidth - drag.offsetLeft : w; h = h >= box.offsetHeight - drag.offsetTop ? box.offsetHeight - drag.offsetTop : h; drag.style.width = w + ’px’; drag.style.height = h + ’px’;}// 鼠標離開和抬起取消縮放drag.onmouseup = function () { drag.onmousemove = null; drag, onmouseup = null;}drag.onmouseleave = function () { drag.onmousemove = null; drag, onmouseup = null;} } } }</script></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 灌装封尾机_胶水灌装机_软管灌装封尾机_无锡和博自动化机械制造有限公司 | 一体化预制泵站-一体化提升泵站-一体化泵站厂家-山东康威环保 | 苏州工作服定做-工作服定制-工作服厂家网站-尺品服饰科技(苏州)有限公司 | 振动台-振动试验台-振动冲击台-广东剑乔试验设备有限公司 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 盐水蒸发器,水洗盐设备,冷凝结晶切片机,转鼓切片机,絮凝剂加药系统-无锡瑞司恩机械有限公司 | 【法利莱住人集装箱厂家】—活动集装箱房,集装箱租赁_大品牌,更放心 | 粘度计,数显粘度计,指针旋转粘度计 | 厌氧反应器,IC厌氧反应器,厌氧三相分离器-山东创博环保科技有限公司 | 欧景装饰设计工程有限公司-无锡欧景装饰官网 | 仿古建筑设计-仿古建筑施工-仿古建筑公司-汉匠古建筑设计院 | 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 高压负荷开关-苏州雷尔沃电器有限公司| 企业微信scrm管理系统_客户关系管理平台_私域流量运营工具_CRM、ERP、OA软件-腾辉网络 | 滤芯,过滤器,滤油机,贺德克滤芯,精密滤芯_新乡市宇清流体净化技术有限公司 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 水平垂直燃烧试验仪-灼热丝试验仪-漏电起痕试验仪-针焰试验仪-塑料材料燃烧检测设备-IP防水试验机 | 平面钻,法兰钻,三维钻-山东兴田阳光智能装备股份有限公司 | 新材料分散-高速均质搅拌机-超声波分散混合-上海化烁智能设备有限公司 | 打包钢带,铁皮打包带,烤蓝打包带-高密市金和金属制品厂 | BOE画框屏-触摸一体机-触控查询一体机-触摸屏一体机价格-厂家直销-触发电子 | 桁架机器人_桁架机械手_上下料机械手_数控车床机械手-苏州清智科技装备制造有限公司 | 刺绳_刀片刺网_刺丝滚笼_不锈钢刺绳生产厂家_安平县浩荣金属丝网制品有限公司-安平县浩荣金属丝网制品有限公司 | 动物麻醉机-数显脑立体定位仪-北京易则佳科技有限公司 | 尊享蟹太太美味,大闸蟹礼卡|礼券|礼盒在线预订-蟹太太官网 | 楼承板设备-楼承板成型机-免浇筑楼承板机器厂家-捡来 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | 精密模具-双色注塑模具加工-深圳铭洋宇通 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 | 哲力实业_专注汽车涂料汽车漆研发生产_汽车漆|修补油漆品牌厂家 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | 食药成分检测_调料配方还原_洗涤剂化学成分分析_饲料_百检信息科技有限公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 北京租车公司_汽车/客车/班车/大巴车租赁_商务会议/展会用车/旅游大巴出租_北京桐顺创业租车公司 | 成都租车_成都租车公司_成都租车网_众行宝 | 预制舱-电力集装箱预制舱-模块化预制舱生产厂家-腾达电器设备 | 智能监控-安防监控-监控系统安装-弱电工程公司_成都万全电子 | 质检报告_CE认证_FCC认证_SRRC认证_PSE认证_第三方检测机构-深圳市环测威检测技术有限公司 | 有机肥设备生产制造厂家,BB掺混肥搅拌机、复合肥设备生产线,有机肥料全部加工设备多少钱,对辊挤压造粒机,有机肥造粒设备 -- 郑州程翔重工机械有限公司 |