大致介绍

拖拽改变元素大小是在模拟拖拽上增加了一些功能
拖拽改变元素大小原理
首先这个方块得知道我们想要改变这个它的大小,所以我给它设定一个范围,当点击这个范围时表明我们想要改变它的大小
当我们点击方块的这些红色区域时,方快就知道我们想要改变它的大小
代码实现:
// 获取event对象,兼容性写法
var ev = ev || event;
// 鼠标按下时的位置
var mouseDownX = ev.clientX;
var mouseDownY = ev.clientY;
// 方块上下左右四个边的位置和方块的长宽
var T0 = this.offsetTop;
var B0 = this.offsetTop + this.offsetHeight;
var L0 = this.offsetLeft;
var R0 = this.offsetLeft + this.offsetWidth;
var W = this.offsetWidth;
var H = this.offsetHeight;
// 设置方块的识别范围
var areaT = T0 + 10;
var areaB = B0 - 10;
var areaL = L0 + 10;
var areaR = R0 - 10;
其中areaT、areaB、areaL、areaR就是红色的区域
接下来方块知道我们想要改变它的大小了,但是要怎么改变,朝哪种方向改变大小。所以要判断改变大小的方向
代码实现:
// 判断改变方块的大小的方向
// 左
var changeL = mouseDownX < areaL;
// 右
var changeR = mouseDownX > areaR;
// 上
var changeT = mouseDownY < areaT;
// 下
var changeB = mouseDownY > areaB;
接下来就是最重要的改变样式了
代码实现:
//根据改变方块大小的方向不同进行大小的改变
// 左
if(changeL){
oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
}
// 右
if(changeR){
oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
}
// 上
if(changeT){
oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
}
// 下
if(changeB){
oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
}
注意:在改变左侧和上侧时要同时修改方块的位置,不然会出现拖左侧边而右侧边位置扩大的现象(拖动上侧边下侧边位置变大)
代码优化
未优化前的代码:
var oDiv = document.getElementById('div1');
oDiv.onmousedown = function(ev){
// 获取event对象,兼容性写法
var ev = ev || event;
// 鼠标按下时的位置
var mouseDownX = ev.clientX;
var mouseDownY = ev.clientY;
// 方块上下左右四个边的位置和方块的长宽
var T0 = this.offsetTop;
var B0 = this.offsetTop + this.offsetHeight;
var L0 = this.offsetLeft;
var R0 = this.offsetLeft + this.offsetWidth;
var W = this.offsetWidth;
var H = this.offsetHeight;
// 设置方块的识别范围
var areaT = T0 + 10;
var areaB = B0 - 10;
var areaL = L0 + 10;
var areaR = R0 - 10;
// 判断改变方块的大小的方向
// 左
var changeL = mouseDownX < areaL;
// 右
var changeR = mouseDownX > areaR;
// 上
var changeT = mouseDownY < areaT;
// 下
var changeB = mouseDownY > areaB;
oDiv.onmousemove = function(ev){
var ev = ev || event;
// 鼠标移动时的鼠标位置
var mouseMoveX = ev.clientX;
var mouseMoveY = ev.clientY;
//根据改变方块大小的方向不同进行大小的改变
// 左
if(changeL){
oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
}
// 右
if(changeR){
oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
}
// 上
if(changeT){
oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
}
// 下
if(changeB){
oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
}
// 限定范围
if(parseInt(oDiv.style.width) < 50){
oDiv.style.width = 50 + 'px';
}
if(parseInt(oDiv.style.height) < 50){
oDiv.style.height = 50 + 'px';
}
}
oDiv.onmouseup = function(){
oDiv.onmousemove = null;
}
}
这段代码现在主要有两个问题:
1、当鼠标移动过快移出方块时,就不能够继续改变元素的大小了
解决方案:把onmousemove事件和onmouseup事件绑定到document对象上
2、当方块中有文字时,拖拽改变方块大小时会触发浏览器默认的原生拖放行为
解决方案:1、阻止浏览器的默认行为(IE8浏览器除外)
在onmousedown中添加语句 return false
2、设置全局捕获(IE8)
在onmousedown中设置全局捕获
在onmouseup中取消全局捕获
优化后的代码:
<div id="div1">adfadsf</div>
<script type="text/javascript">
var oDiv = document.getElementById('div1');
oDiv.onmousedown = function(ev){
// 获取event对象,兼容性写法
var ev = ev || event;
// 鼠标按下时的位置
var mouseDownX = ev.clientX;
var mouseDownY = ev.clientY;
// 方块上下左右四个边的位置和方块的长宽
var T0 = this.offsetTop;
var B0 = this.offsetTop + this.offsetHeight;
var L0 = this.offsetLeft;
var R0 = this.offsetLeft + this.offsetWidth;
var W = this.offsetWidth;
var H = this.offsetHeight;
// 设置方块的识别范围
var areaT = T0 + 10;
var areaB = B0 - 10;
var areaL = L0 + 10;
var areaR = R0 - 10;
// 判断改变方块的大小的方向
// 左
var changeL = mouseDownX < areaL;
// 右
var changeR = mouseDownX > areaR;
// 上
var changeT = mouseDownY < areaT;
// 下
var changeB = mouseDownY > areaB;
// IE8 取消默认行为-设置全局捕获
if(oDiv.setCapture){
oDiv.setCapture();
}
document.onmousemove = function(ev){
var ev = ev || event;
// 鼠标移动时的鼠标位置
var mouseMoveX = ev.clientX;
var mouseMoveY = ev.clientY;
//根据改变方块大小的方向不同进行大小的改变
// 左
if(changeL){
oDiv.style.width = (mouseDownX - mouseMoveX) + W + 'px';
oDiv.style.left = L0 - (mouseDownX - mouseMoveX) + 'px';
}
// 右
if(changeR){
oDiv.style.width = (mouseMoveX - mouseDownX) + W + 'px';
}
// 上
if(changeT){
oDiv.style.height = (mouseDownY - mouseMoveY) + H + 'px';
oDiv.style.top = T0 - (mouseDownY - mouseMoveY) + 'px';
}
// 下
if(changeB){
oDiv.style.height = (mouseMoveY - mouseDownY) + H +'px';
}
// 限定范围
if(parseInt(oDiv.style.width) < 50){
oDiv.style.width = 50 + 'px';
}
if(parseInt(oDiv.style.height) < 50){
oDiv.style.height = 50 + 'px';
}
}
document.onmouseup = function(){
document.onmousemove = null;
// 释放全局捕获
if(oDiv.releaseCapture){
oDiv.releaseCapture();
}
}
return false;
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js
# 拖拽
# javascript
# vuejs2.0运用原生js实现简单拖拽元素功能
# vuejs2.0运用原生js实现简单的拖拽元素功能示例
# JavaScript实现拖拽元素对齐到网格(每次移动固定距离)
# jquery插件jquery.dragscale.js实现拖拽改变元素大小的方法(附demo源码下载
# JavaScript实现拖拽网页内元素的方法
# javascript实现拖拽并替换网页块元素
# js实现拖拽元素选择和删除
# 鼠标
# 上下左右
# 按下
# 长宽
# 是在
# 就不
# 最重要
# 中有
# 这段
# 当我们
# 拖动
# 哪种
# 过快
# 时要
# 绑定
# 给它
# 变大
# 拖放
# 增加了
相关文章:
建站之星安装后如何配置SEO及设计样式?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
寿县云建站:智能SEO优化与多行业模板快速上线指南
大连 网站制作,大连天途有线官网?
,怎么在广州志愿者网站注册?
如何通过远程VPS快速搭建个人网站?
c# await 一个已经完成的Task会发生什么
建站之星展会模版如何一键下载生成?
小建面朝正北,A点实际方位是否存在偏差?
如何快速打造个性化非模板自助建站?
西安专业网站制作公司有哪些,陕西省建行官方网站?
如何快速生成凡客建站的专业级图册?
浅析上传头像示例及其注意事项
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
网站按钮制作软件,如何实现网页中按钮的自动点击?
制作电商网页,电商供应链怎么做?
建站主机选购指南:核心配置与性价比推荐解析
如何用景安虚拟主机手机版绑定域名建站?
建站ABC备案流程中有哪些关键注意事项?
制作网站怎么制作,*游戏网站怎么搭建?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
如何选择高效便捷的WAP商城建站系统?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
建站主机核心功能解析:服务器选择与网站搭建流程指南
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
如何在云主机上快速搭建网站?
如何通过二级域名建站提升品牌影响力?
公司网站设计制作厂家,怎么创建自己的一个网站?
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何通过多用户协作模板快速搭建高效企业网站?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
如何配置FTP站点权限与安全设置?
建站之星如何通过成品分离优化网站效率?
清除minerd进程的简单方法
宝塔建站助手安装配置与建站模板使用全流程解析
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
高端建站如何打造兼具美学与转化的品牌官网?
电商网站制作公司有哪些,1688网是什么意思?
高端企业智能建站程序:SEO优化与响应式模板定制开发
网站网页制作专业公司,怎样制作自己的网页?
简单实现Android验证码
建站主机如何选?高性价比方案全解析
如何快速搭建高效WAP手机网站吸引移动用户?
制作旅游网站html,怎样注册旅游网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。