给组件添加拖拽对齐辅助线

本文首发于个人博客网站

https://iiter.cn/blogs/33

之前用伪元素before和after实现了一版组件对齐辅助线,组件的拖拽缩放用的是这个库 Github直达
实现的功能为:点击组件的时候,组件高亮并且辅助线在左上角显示。如下图

奈何,领导看了不满意
说你这玩意拖拽的时候得四个角都实现啊。
并且说得是在拖拽移动的过程中才能出现,点击激活,组件高亮的时候不显示。
这…可把我给难住了
我着急啊,我上火啊,一缕缕的揪头发啊
愁完之后咋整啊,功能还得做啊不是
打开代码,随手给组件内部创建了四个positionabsolute的div。辅助线想多长,宽高就给多长,咱里给的是500px 咱也不知道为啥要给500,反正跟250是亲戚
哦当然,父组件必须要有position
左上右上左下右下各分配一个div,因有1px边框,辅助线div的left和top的绝对值多+2
左上角div样式如下,将左、上边框置为none。

.guide-leftTop {
    left: -502px;
    top: -502px;
    border: 1px dashed #2ab1e8;
    border-top: none;
    border-left: none;
}

右上角div样式如下,将右、上边框置为none。

.guide-rightTop {
  right: -502px;
  top: -502px;
  border: 1px dashed #2ab1e8;
  border-top: none;
  border-right: none;
}

左下角div样式如下,将左、下边框置为none。

.guide-leftBottom {
  left: -502px;
  bottom: -502px;
  border: 1px dashed #2ab1e8;
  border-bottom: none;
  border-left: none;
}

右下角div样式如下,将右、下边框置为none。

.guide-rightBottom {
  right: -502px;
  bottom: -502px;
  border: 1px dashed #2ab1e8;
  border-right: none;
  border-bottom: none;
}

可以打开浏览器测试一番了,出来之后的样式酱紫的:
激活:

不激活:

我去,这竟然…好难看的样子!
说好的只在拖拽情况下显示呢???眼角流出的泪水,是我对生活的无奈!
又开始挠起了头发,摸着这日益增高的发际线…
嗯想了想 貌似可以通过拖拽的时候给添加动态class名去实现呀。
我激动不已,仿佛在我20多年的人生道路上又重新看到了希望,苍天有眼呐!
组件的class名为mw-widget,创建一个包裹所有辅助线div的class名mw-widget-show-guide,把它们紧紧的裹起来,放到和mw-widget的class名平级的地方,层级顺序在less或者scss下是酱紫的:

.mw-widget{
    //...
}
.mw-widget-show-guide{
    .guide-leftTop{
        //...
    }
    .guide-rightTop{}
    .guide-leftBottom{}
    .guide-rightBottom{}
}

之后,在我们拖拽组件onmousedown的过程中,给当前组件动态添加class名mw-widget-show-guide,再在其onmouseup的时候,移除掉class名mw-widget-show-guide,效果是下面这样:

完美!
高!实在是高!旁边的同事一边看着我的发际线,一边对我说。
程序员导航站 https://iiter.cn

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现拖拽组件的互换功能,可以通过以下步骤进行: 1. 给每个可拖拽组件添加一个唯一标识符,例如id。 2. 在拖拽开始时,记录被拖拽组件的id和其它需要的信息。 3. 在拖拽结束时,获取拖拽结束位置的组件id和其它需要的信息。 4. 如果被拖拽组件拖拽结束位置的组件不是同一个组件,则进行位置互换。 5. 更新组件的位置信息,重新渲染组件。 以下是一个简单的实现代码示例: ```html <template> <div> <div class="draggable" v-for="item in items" :key="item.id" :draggable="true" @dragstart="dragStart(item)" @dragend="dragEnd"> {{ item.name }} </div> </div> </template> <script> export default { data() { return { items: [ { id: 1, name: '组件1' }, { id: 2, name: '组件2' }, { id: 3, name: '组件3' }, ], draggingItem: null, }; }, methods: { dragStart(item) { this.draggingItem = item; }, dragEnd(event) { const dropTarget = event.target; const dropItemId = dropTarget.getAttribute('data-id'); if (dropItemId && this.draggingItem.id !== parseInt(dropItemId)) { const dropIndex = this.items.findIndex(item => item.id === parseInt(dropItemId)); const dragIndex = this.items.findIndex(item => item.id === this.draggingItem.id); this.items.splice(dropIndex, 1, this.draggingItem); this.items.splice(dragIndex, 1, { ...this.items[dropIndex] }); } this.draggingItem = null; }, }, }; </script> ``` 在上述代码中,我们给每个可拖拽组件添加了一个id属性,并在拖拽开始时记录了被拖拽组件的信息。在拖拽结束时,我们获取了拖拽结束位置的组件id,并判断是否需要进行位置互换。如果需要互换位置,则使用splice方法进行位置互换,并重新渲染组件

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值