通过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中in运算符用法分析
Apr 28 Javascript
JavaScript获取当前cpu使用率的方法
Dec 15 Javascript
javaScript语法总结
Nov 25 Javascript
jquery鼠标悬停导航下划线滑出效果
Sep 29 jQuery
详解Angular2学习笔记之Html属性绑定
Jan 03 Javascript
node内置调试方法总结
Feb 22 Javascript
动态加载JavaScript文件的3种方式
May 05 Javascript
jQuery实现导航样式布局操作示例【可自定义样式布局】
Jul 24 jQuery
JavaScript实现好看的跟随彩色气泡效果
Feb 06 Javascript
js表达式与运算符简单操作示例
Feb 15 Javascript
vue相关配置文件详解及多环境配置详细步骤
May 19 Javascript
vue使用swiper实现左右滑动切换图片
Oct 16 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
SONY ICF-SW07收音机电路分析
2021/03/02 无线电
php生成带logo二维码方法小结
2016/04/08 PHP
php插件Xajax使用方法详解
2017/08/31 PHP
textContent在Firefox下与innerText等效的属性
2007/05/12 Javascript
关于IE BUG与字符串截取substr的解决办法
2013/04/10 Javascript
jquery实现省市select下拉框的替换(示例代码)
2014/02/22 Javascript
jquery实现标签支持图文排列带上下箭头按钮的选项卡
2015/03/14 Javascript
php结合imgareaselect实现图片裁剪
2015/07/05 Javascript
快速实现jQuery多级菜单效果
2017/02/01 Javascript
js实现类bootstrap模态框动画
2017/02/07 Javascript
利用Javascript开发一个二维周视图日历
2017/12/14 Javascript
JS中的JSON对象的定义和取值实现代码
2018/05/09 Javascript
vue实现动态列表点击各行换色的方法
2018/09/13 Javascript
vue-router启用history模式下的开发及非根目录部署方法
2018/12/23 Javascript
Vue路由守卫及页面登录权限控制的设置方法(两种)
2020/03/31 Javascript
Python Mysql自动备份脚本
2008/07/14 Python
python列表的常用操作方法小结
2016/05/21 Python
python实现xlsx文件分析详解
2018/01/02 Python
详解python3安装pillow后报错没有pillow模块以及没有PIL模块问题解决
2019/04/17 Python
python制作简单五子棋游戏
2019/06/18 Python
解决pycharm 安装numpy失败的问题
2019/12/05 Python
Python调用OpenCV实现图像平滑代码实例
2020/06/19 Python
python爬虫数据保存到mongoDB的实例方法
2020/07/28 Python
世界上最大的家庭自动化公司:Smarthome
2017/12/20 全球购物
Shopbop中文官网:美国亚马逊旗下时尚购物网站
2020/12/15 全球购物
测控技术与通信工程毕业生自荐信范文
2013/12/28 职场文书
大学生自我鉴定评语
2014/01/27 职场文书
教师自我反思材料
2014/02/14 职场文书
十八届三中全会感言
2014/03/10 职场文书
超市仓管员岗位职责
2014/04/07 职场文书
党风廉设责任书
2014/04/16 职场文书
应届毕业生自荐书
2014/06/18 职场文书
环境日宣传活动总结
2014/07/09 职场文书
2016优秀护士求职自荐信
2016/01/28 职场文书
2016创先争优活动党员公开承诺书
2016/03/24 职场文书
党风廉政承诺书2016
2016/03/25 职场文书