通过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 相关文章推荐
网页里控制图片大小的相关代码
Jun 13 Javascript
Jquery 实现图片轮换
Jan 28 Javascript
JS实现仿新浪微博发布内容为空时提示功能代码
Aug 19 Javascript
js手动播放图片实现图片轮播效果
Sep 17 Javascript
Ubuntu 16.04 64位中搭建Node.js开发环境教程
Oct 19 Javascript
Vue2.0 多 Tab切换组件的封装实例
Jul 28 Javascript
javascript基于牛顿迭代法实现求浮点数的平方根【递归原理】
Sep 28 Javascript
JSONP原理及应用实例详解
Sep 13 Javascript
如何用Node写页面爬虫的工具集
Oct 26 Javascript
Angular父子组件通过服务传参的示例方法
Oct 31 Javascript
原生js滑动轮播封装
Jul 31 Javascript
JavaScript最完整的深浅拷贝实现方式详解
Feb 28 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
php中使用Imagick实现图像直方图的实现代码
2011/08/30 PHP
php中in_array函数用法分析
2014/11/15 PHP
mod_php、FastCGI、PHP-FPM等PHP运行方式对比
2015/07/02 PHP
Symfony2学习笔记之控制器用法详解
2016/03/17 PHP
php高性能日志系统 seaslog 的安装与使用方法分析
2020/02/29 PHP
再说AutoComplete自动补全之实现原理
2011/11/05 Javascript
jQuery插件开发全解析
2012/10/10 Javascript
jQuery对html元素取值与赋值的方法
2013/11/20 Javascript
浅析JavaScript中的同名标识符优先级
2013/12/06 Javascript
js监听鼠标点击和键盘点击事件并自动跳转页面
2014/09/24 Javascript
轻松学习jQuery插件EasyUI EasyUI实现拖动基本操作
2015/11/30 Javascript
js操作数组函数实例小结
2015/12/10 Javascript
Angularjs material 实现搜索框功能
2016/03/08 Javascript
Angularjs 制作购物车功能实例代码
2016/09/14 Javascript
浅谈js函数三种定义方式 &amp; 四种调用方式 &amp; 调用顺序
2017/02/19 Javascript
Bootstrap table 定制提示语的加载过程
2017/02/20 Javascript
Angular2安装angular-cli
2017/05/21 Javascript
深入讲解xhr(XMLHttpRequest)/jsonp请求之abort
2017/07/26 Javascript
javascript 中事件冒泡和事件捕获机制的详解
2017/09/01 Javascript
vue-cli下的vuex的简单Demo图解(实现加1减1操作)
2018/02/26 Javascript
JS实现的tab页切换效果完整示例
2018/12/18 Javascript
微信小程序实现限制用户转发功能的实例代码
2020/02/22 Javascript
python实现批量获取指定文件夹下的所有文件的厂商信息
2014/09/28 Python
用Python实现一个简单的线程池
2015/04/07 Python
Django接收post前端返回的json格式数据代码实现
2019/07/31 Python
python lambda表达式在sort函数中的使用详解
2019/08/28 Python
安装Pycharm2019以及配置anconda教程的方法步骤
2019/11/11 Python
css3绘制百度的小度熊
2018/10/29 HTML / CSS
高档奢华时装在线目的地:FORWARD by elyse walker
2017/10/16 全球购物
大专计算机个人求职的自我评价
2013/10/21 职场文书
大学生就业自我鉴定
2013/10/26 职场文书
《最后的姿势》教学反思
2014/02/27 职场文书
优秀三好学生事迹材料
2014/08/31 职场文书
运动会新闻稿
2015/07/17 职场文书
sql server 累计求和实现代码
2022/02/28 SQL Server
使用Ajax实现无刷新上传文件
2022/04/12 Javascript