基于jquery的用鼠标画出可移动的div
jQuery 基于 移动 鼠标 div 画出
2023-06-13 09:14:35 时间
具体的原理我就不多说了,直接贴代码。
html代码:
复制代码代码如下:
html代码:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Drawrectangle</title>
<metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/>
<scriptsrc="jquery-1.6.2.min.js"type="text/javascript"></script>
<scriptsrc="jquery.ui.core.js"type="text/javascript"></script>
<scriptsrc="jquery.ui.widget.js"type="text/javascript"></script>
<scriptsrc="jquery.ui.mouse.js"type="text/javascript"></script>
<scriptsrc="jquery.ui.draggable.js"type="text/javascript"></script>
<linkhref="catch.css"rel="stylesheet"type="text/css";charset=gb2312/>
<scriptsrc="catch.js"type="text/javascript";charset=gb2312></script>
<!--[ifgteIE7]>
<styletype="text/css">
</style>
<![endif]-->
</head>
<body>
<!--header-->
<divid="header">
<label>Draw!</label>
</div>
<!--content-->
<divid="content">
</div>
<!--bottom-->
<divid="bottom">
</div>
</body>
</html>
css代码:
body
{
font-family:"HelveticaNeue","LucidaGrande","SegoeUI",Arial,Helvetica,Verdana,sans-serif;
margin:0px;
}
#header
{
width:150px;
margin:0pxauto;
}
#headerlabel
{
font-size:45px;
font-weight:bolder;
}
#content
{
width:90%;
height:600px;
margin:10pxauto;
border:1pxsolidblue;
}
.new_rect
{
opacity:0.7;
-moz-opacity:0.7;
filter:alpha(opacity=70);
-ms-filter:alpha(opacity=70);
background:#A8CAEC;
border:1pxsolid#3399FF;
position:fixed;
float:left;
}
.new_rect:hover{
cursor:move;
}
.mousedown{
-webkit-box-shadow:5px5px5pxblack;
-moz-box-shadow:5px5px5pxblack;
box-shadow:5px5px5pxblack;
z-index:999;
}
js代码:
//////////////////////////////////////////////////////////
$(function(){
//$("div[title=new_rect]").click(function(){alert("click");});
//$(".new_rect").draggable();
drow_rect("#content");
})
/////////////////////////////////////////////////////////
functiondrow_rect(the_id){//theid表示用作画布的层
varnum=1;
varx_down=0,y_down=0;
varnew_width=0,new_height=0;
varx_original=0,y_original=0;
varoriginal_flag=true,down_flag=false;
varx_point=0,y_point=0;
varappend_string;
varMouseDown=function(e){
down_flag=true;
x_down=e.pageX;
y_down=e.pageY;//记录鼠标的当前坐标
if(original_flag){//如果是第一次点击,把起始点的坐标记录到x_original和y_original中
x_original=e.pageX;
y_original=e.pageY;
original_flag=false;
}
};
varMouseMove=function(e){
if(down_flag){//鼠标有移动
x_down=e.pageX;
y_down=e.pageY;
x_point=x_original;
y_point=y_original;
new_width=x_down-x_original;
if(new_width<0){//鼠标向左运动
new_width=-new_width;
x_point=x_down;
}
new_height=y_down-y_original;
if(new_height<0){//鼠标向右运动
new_height=-new_height;
y_point=y_down;
}
$("div[name=""+num+""]").remove();//把前面的层删除,并在后面的代码中生成新的层
append_string="<divclass="new_rect"style="left:"+x_point+"px;top:"+y_point+"px;"+"width:"+new_width+"px;height:"
+new_height+"px"name=""+num+""title="第"+num+"个"></div>";
$(the_id).append(append_string);
}
}
$(the_id).bind("mousedown",MouseDown);
$(the_id).bind("mousemove",MouseMove);//事件绑定
$(the_id).mouseup(function(e){//松开鼠标左键,初始化标志位
down_flag=false;
original_flag=true;
$("div[name=""+num+""]").draggable();
$("div[name=""+num+""]").mousedown(function(){
$(this).addClass("mousedown");//添加阴影
$(the_id).unbind("mousedown",MouseDown);
$(the_id).unbind("mousemove",MouseMove);//取消事件绑定
});
$("div[name=""+num+""]").mouseup(function(){
$(this).removeClass("mousedown");//删除阴影
$(the_id).bind("mousedown",MouseDown);
$(the_id).bind("mousemove",MouseMove);//事件绑定
});
num++;
});
}
上传一个实例图片:
相关文章
- jquery layui的巨坑详解编程语言
- javascript基于jQuery的表格悬停变色/恢复,表格点击变色/恢复,点击行选Checkbox
- JQuery困惑—包装集DOM节点
- JQuery网站换肤功能实现代码
- 基于JQuery框架的AJAX实例代码
- 基于jQuery的js分页代码
- jquery多浏览器捕捉回车事件代码
- 基于jQuery架构javascript基础体系
- 基于jquery的合并table相同单元格的插件(精简版)
- 基于jquery的监控数据是否发生改变
- 基于jQuery替换table中的内容并显示进度条的代码
- jquery入门—编写一个导航条(可伸缩)
- jquery无限级联菜单案例分享
- 基于jQuery.Validate验证库知识点的详解
- 基于jquery的has()方法以及与find()方法以及filter()方法的区别详解
- JQuery中关于jquery.js与jquery.min.js的比较探讨
- jquery实现带复选框的表格行选中删除时高亮显示
- 基于jquery扩展漂亮的CheckBox(自己编写)
- jquery.cookie用法详细解析
- JQuery结合CSS操作打印样式的方法
- Jquery创建层显示标题和内容且随鼠标移动而移动
- 基于JQuery实现的Select级联
- jquery禁用右键单击功能屏蔽F5刷新
- jquery解析xml字符串示例分享
- jQuery过滤选择器:not()方法使用介绍
- 在页面加载完成后通过jquery给多个span赋值
- 基于jQuery实现文本框缩放以及上下移动功能
- 使用JavaScript链式编程实现模拟Jquery函数
- 自己动手手写jQuery插件总结
- jquery向上向下取整适合分页查询
- 基于jquery的文字向上跑动类似跑马灯的效果