Vue.js实现拖放效果的实例
2016-09-30 10:45
1086 查看
页面效果如下所示:
代码请看这里,当当当当:
html:
<template> <div class='drag-content'> <div class='project-content'> <div class='select-item' draggable='true' @dragstart='drag($event)' v-for='pjdt in projectdatas'>{{pjdt.name}}</div> </div> <div class='people-content'> <div class='drag-div' v-for='(ppindex,ppdt) in peopledata' @drop='drop($event)' @dragover='allowDrop($event)'> <div class='select-project-item'> <label class='drag-people-label'>{{ppdt.name}}:</label> </div> </div> </div> </div> </template> <div class='select-item' draggable='true' @dragstart='drag($event)' v-for='pjdt in projectdatas'>{{pjdt.name}}</div>
在这行代码中小颖在绑定dragstart事件时,drag($event)写法和js写法不一样,如果你在vue中绑定事件时要传 'event',你不能像js那种格式去写 ,比如:@dragstart='drag(event)' 这个写的话你在drag方法中获取到的event是 undefined,因为它把 @dragstart='drag(event)' 中的event当成了一个变量,而该变量并没有在data中定义所以就是 undefined.早上小颖就碰到过此坑.所以切记格式是介个酱紫的: @dragstart='drag($event)'
js代码:
<script> let dom = null export default { components: { }, ready: function() { }, methods: { drag:function(event){ dom = event.currentTarget }, drop:function(event){ event.preventDefault(); event.target.appendChild(dom); }, allowDrop:function(event){ event.preventDefault(); }, }, data() { return { projectdatas:[{ id:1, name:'葡萄', },{ id:2, name:'芒果', },{ id:3, name:'木瓜', },{ id:4, name:'榴莲', }], peopledata:[{ id:1, name:'小颖', },{ id:2, name:'hover', },{ id:3, name:'空巢青年三 ', },{ id:3, name:'一丢丢', }] } } } </script>
以上所述是小编给大家介绍的Vue.js实现拖放效果的实例,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- JS实现遮罩层效果的简单实例
- js实现单行文本向上滚动效果实例代码
- js实现网页标题栏闪烁提示效果实例分析
- js实现支持手机滑动切换的轮播图片效果实例
- js+css实现导航效果实例
- JS+DIV实现鼠标划过切换层效果的实例代码
- JS、jquery实现几分钟前、几小时前、几天前等时间差显示效果的代码实例分享
- js实现点击左右按钮轮播图片效果实例
- JS实现倒计时和文字滚动的效果实例
- js实现支持手机滑动切换的轮播图片效果实例
- JS小功能(setInterval实现图片效果显示时间)实例代码
- js实现省市联动效果的简单实例
- JS小功能(setInterval实现图片效果显示时间)实例代码
- js实现点击左右按钮轮播图片效果实例
- js实现收缩菜单效果实例代码
- JS小功能(offsetLeft实现图片滚动效果)实例代码
- JS实现模仿微博发布效果实例代码
- js实现省市联动效果的简单实例
- js实现百度联盟中一款不错的图片切换效果完整实例
- js+css实现导航效果实例