拖动的div



<head><title></title>
<style>
body
{
font-size:12px;
color:#333333;
border : 0px solid blue;
}
div
{
position : absolute;
background-color : #c3d9ff;
margin : 0px;
padding : 5px;
border : 0px;
width : 100px;
height:100px;
}
</style>
</head>
<body>
<script>
function drag(o,s)
{
if (typeof o == "string") o = document.getElementById(o);
o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
o.orig_y = parseInt(o.style.top) - document.body.scrollTop;
o.orig_index = o.style.zIndex;

o.onmousedown = function(a)
{
this.style.cursor = "move";
this.style.zIndex = 10000;
var d=document;
if(!a)a=window.event;
var x = a.clientX+d.body.scrollLeft-o.offsetLeft;
var y = a.clientY+d.body.scrollTop-o.offsetTop;

d.ondragstart = "return false;"
d.onselectstart = "return false;"
d.onselect = "document.selection.empty();"

if(o.setCapture)
o.setCapture();
else if(window.captureEvents)
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
d.onmousemove = function(a)
{
if(!a)a=window.event;
o.style.left = a.clientX+document.body.scrollLeft-x;
o.style.top = a.clientY+document.body.scrollTop-y;
o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
o.orig_y = parseInt(o.style.top) - document.body.scrollTop;
}
d.onmouseup = function()
{
if(o.releaseCapture)
o.releaseCapture();
else if(window.captureEvents)
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
d.onmousemove = null;
d.onmouseup = null;
d.ondragstart = null;
d.onselectstart = null;
d.onselect = null;
o.style.cursor = "normal";
o.style.zIndex = o.orig_index;
}
}

if (s)
{
var orig_scroll = window.onscroll?window.onscroll:function (){};
window.onscroll = function ()
{
orig_scroll();
o.style.left = o.orig_x + document.body.scrollLeft;
o.style.top = o.orig_y + document.body.scrollTop;
}
}
}
</script>
<div id="div1" style="left:10px;top:10px;">div1:拖吧,往死里拖</div>
<div id="div2" style="left:120px;top:10px;background-color : #f3d9ff">div2:来拖我呀</div>
<div id="div3" style="left:230px;top:10px;background-color : #c3ffff">div3:随你怎么拖</div>
<div id="div4" style="left:10px;top:120px;background-color : #c3d944">div4:我可以随窗口滑动,把我拖到最下面,然后滚动网页看看</div>
<div id="div5" style="left:120px;top:120px;background-color : #f3d944">php同盟会<br/><a href=http://www.dophp.net target=_blank>www.dophp.net</a>
</div>
<div id="div6" style="left:230px;top:120px;background-color : #e3f944;width:200px;">参数说明:<br/>
drag(obj [,scroll]);<br/>
obj:对象的id或对象本身;<br/>
scroll(可选):对象是否随窗口拖动而滑动,默认为否<br/>
鼠标右键查看源代码
</div>

<script>
drag("div1");
drag("div2");
drag("div3");
drag("div4",1);
drag("div5",1);
drag("div6",1);

</script>
</body>
vuedraggable是一个基于Vue.js的拖拽组件,它可以帮助我们实现在页面上拖拽元素的功能。下面是使用vuedraggable拖拽div的简单介绍: 1. 首先,你需要在你的Vue项目中安装vuedraggable。可以通过npm或者yarn进行安装: ``` npm install vuedraggable ``` 2. 在你的Vue组件中引入vuedraggable: ```javascript import draggable from 'vuedraggable' ``` 3. 在模板中使用vuedraggable组件,并绑定一个数组作为拖拽的数据源: ```html <draggable v-model="items"> <div v-for="item in items" :key="item.id">{{ item.name }}</div> </draggable> ``` 这里的`items`是一个数组,用于存储拖拽的元素。通过`v-model`指令将`items`与vuedraggable组件进行双向绑定。 4. 在Vue组件的data选项中定义`items`数组,并初始化一些拖拽元素的数据: ```javascript data() { return { items: [ { id: 1, name: 'Div 1' }, { id: 2, name: 'Div 2' }, { id: 3, name: 'Div 3' } ] } } ``` 这里的`items`数组中包含了三个拖拽元素的数据,每个元素都有一个唯一的`id`和一个`name`属性。 5. 最后,你可以根据需要自定义拖拽元素的样式,并在拖拽结束后监听`change`事件来获取拖拽后的数据: ```html <draggable v-model="items" @change="handleDragEnd"> <div v-for="item in items" :key="item.id" class="drag-item">{{ item.name }}</div> </draggable> ``` 在上面的例子中,我们给拖拽元素添加了一个名为`drag-item`的类,可以通过CSS来自定义该类的样式。 至此,你已经完成了使用vuedraggable拖拽div的基本操作。你可以根据需要进一步扩展和定制该组件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值