通过angular CDK实现页面元素拖放的步骤详解


Posted in Javascript onJuly 01, 2020

通过导入@angular/cdk/drag-drop模块我们可以轻松实现元素在页面中得拖放功能,如元素在页面中随意拖动、在特定区域内拖动亦或对列表进行拖放排序等等。

CDK. The Component Dev Kit (CDK) is a set of tools that implement common interaction patterns whilst being unopinionated about their presentation. It represents an abstraction of the core functionalities found in the Angular Material library, without any styling specific to Material Design.

WEB项目中有些场景会使用元素拖动效果,那么对于angular项目我们可以通过导入“@angular/cdk/drag-drop”模块轻松实现元素自由拖动效果。

首先我们会创建拖放对象,如同:

<div class="drag">拖动元素</div>
.drag{
 position:absolute;
 left:0;
 bottom:0;
 border:1px grey solid;
 width:60px;
 height:60px;
 cursor: move;
 z-index:1;
}

然后我们在相应模块中导入拖动模块即可。

import { DragDropModule } from '@angular/cdk/drag-drop'

在页面中,我们就可以直接使用其指令实现(cdDrag)。

<div class="drag" cdkDrag></div>

即可实现自由拖动效果。

通过angular CDK实现页面元素拖放的步骤详解

angular cdk drag-drop

我们可以实现自由拖放、列表重新排序、列表间数据传输、特指拖放控制、及其拖放临界点控制等等。

拖动元素内指定拖动控制,如:

<div class="drag" cdkDrag>
 <span cdkDragHandle class="dragHandle"></span>
</div>

通过父级 cdkDrag 与 控制子级控制元素 cdkDragHandle 对其作用。

设置拖动临界点,限制在指定区域进行自由拖动。

如果要阻止用户将cdkDrag元素拖动到另一个元素之外,可以将CSS选择器传递给该cdkDragBoundary属性。该属性通过接受选择器并查找DOM直到找到与其匹配的元素为止。如果找到匹配项,则将其用作不能拖动元素的边界。放在里面cdkDragBoundary时也可以使用。

通过angular CDK实现页面元素拖放的步骤详解

Angular cdkDrag Y轴拖动

如在body中拖动,禁止拖放至不可见,或通过css选择器指定临界点

<div class="drag" cdkDrag>
 <span cdkDragHandle cdkDragBoundary="body" class="dragHandle"></span>
</div>

亦或我们可以控制仅在X轴方向或Y轴方向拖动

<div class="drag" cdkDragLockAxis = "x" cdkDrag>
 <span cdkDragHandle cdkDragBoundary="body" class="dragHandle"></span>
</div>

通过cdkDragLockAxis = "x" 或 cdkDragLockAxis = "y"控制。

更多大家可以参考官方介绍,临时使用予以笔记,仅供参考!

总结

到此这篇关于通过angular CDK实现页面元素拖放的文章就介绍到这了,更多相关angular CDK页面元素拖放内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
开发跨浏览器javascript常见注意事项
Jan 01 Javascript
Javascript实现的鼠标经过时播放声音
May 18 Javascript
javascript学习笔记(二十) 获得和设置元素的特性(属性)
Jun 20 Javascript
js 实现 input type=&quot;file&quot; 文件上传示例代码
Aug 07 Javascript
浅谈JavaScript 框架分类
Nov 10 Javascript
javascript iframe跨域详解
Oct 26 Javascript
浅谈JavaScript事件绑定的常用方法及其优缺点分析
Nov 01 Javascript
如何利用JQuery实现从底部回到顶部的功能
Dec 27 Javascript
js判断是否是手机页面
Mar 17 Javascript
angular 用拦截器统一处理http请求和响应的方法
Jun 08 Javascript
vue axios 给生产环境和发布环境配置不同的接口地址(推荐)
May 08 Javascript
Vue.js特性Scoped Slots的浅析
Feb 20 Javascript
微信小程序用户盒子、宫格列表的实现
Jul 01 #Javascript
vue商城中商品“筛选器”功能的实现代码
Jul 01 #Javascript
vue实现购物车列表
Jun 30 #Javascript
vue实现简单图片上传
Jun 30 #Javascript
vue基于better-scroll仿京东分类列表
Jun 30 #Javascript
vue使用better-scroll实现滑动以及左右联动
Jun 30 #Javascript
vue基于better-scroll实现左右联动滑动页面
Jun 30 #Javascript
You might like
在WIN98下以apache模块方式安装php
2006/10/09 PHP
增加反向链接的101个方法 站长推荐
2007/01/31 PHP
PHP实现登录搜狐广告获取广告联盟数据的方法【附demo源码】
2016/10/14 PHP
php设计模式之正面模式实例分析【星际争霸游戏案例】
2020/03/24 PHP
tp5.1 框架数据库-数据集操作实例分析
2020/05/26 PHP
javascript Discuz代码中的msn聊天小功能
2008/05/25 Javascript
js操作ajax返回的json的注意问题!
2010/02/23 Javascript
判断在css加载完毕后执行后续代码示例
2014/09/03 Javascript
JavaScript函数模式详解
2014/11/07 Javascript
jQuery操作iframe中js函数的方法小结
2016/07/06 Javascript
JS匿名函数实例分析
2016/11/26 Javascript
canvas基础绘制-绚丽倒计时的实例
2017/09/17 Javascript
微信小程序如何获取地址
2019/12/24 Javascript
vue实现输入框自动跳转功能
2020/05/20 Javascript
Vant picker 多级联动操作
2020/11/02 Javascript
jquery实现鼠标悬浮弹出气泡提示框
2020/12/23 jQuery
[32:07]完美世界DOTA2联赛PWL S3 LBZS vs Rebirth 第一场 12.16
2020/12/17 DOTA
Python使用Flask框架同时上传多个文件的方法
2015/03/21 Python
微信跳一跳python代码实现
2018/01/05 Python
pandas 使用apply同时处理两列数据的方法
2018/04/20 Python
python将txt文件读入为np.array的方法
2018/10/30 Python
对pandas的算术运算和数据对齐实例详解
2018/12/22 Python
python ftplib模块使用代码实例
2019/12/31 Python
pytorch GAN伪造手写体mnist数据集方式
2020/01/10 Python
如何用Python提取10000份log中的产品信息
2021/01/14 Python
html5使用canvas绘制一张图片
2014/12/15 HTML / CSS
查询优化的一般准则有哪些
2015/03/08 面试题
linux面试题参考答案(5)
2016/11/05 面试题
经营管理策划方案
2014/05/22 职场文书
大学新闻系应届生求职信
2014/06/02 职场文书
公司授权委托书
2014/10/17 职场文书
英文升职感谢信
2015/01/23 职场文书
煤矿安全学习心得体会
2016/01/18 职场文书
学校2016年全国助残日活动总结
2016/04/01 职场文书
如何用JavaScipt测网速
2021/05/09 Javascript
python opencv将多个图放在一个窗口的实例详解
2022/02/28 Python