通过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 日历提醒系统( 兼容所有浏览器 )
Apr 07 Javascript
浅谈tudou土豆网首页图片延迟加载的效果
Jun 23 Javascript
JavaScript中的一些定位属性[图解]
Jul 14 Javascript
js 获取计算后的样式写法及注意事项
Feb 25 Javascript
javascript 小数取整简单实现方式
May 30 Javascript
js图片轮播手动切换效果
Nov 10 Javascript
vue.js指令v-model实现方法
Dec 05 Javascript
有关JS中的0,null,undefined,[],{},'''''''',false之间的关系
Feb 14 Javascript
javascript高仿热血传奇游戏实现代码
Feb 22 Javascript
vue-router history模式下的微信分享小结
Jul 05 Javascript
Bootstrap 按钮样式与使用代码详解
Dec 09 Javascript
微信小程序实现原生步骤条
Jul 25 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
杏林同学录(六)
2006/10/09 PHP
一个简单的PHP投票程序源码
2007/03/11 PHP
php递归法读取目录及文件的方法
2015/01/30 PHP
PHP制作用户注册系统
2015/10/23 PHP
PHP利用pdo_odbc实现连接数据库示例【基于ThinkPHP5.1搭建的项目】
2019/05/13 PHP
php使用pthreads v3多线程实现抓取新浪新闻信息操作示例
2020/02/21 PHP
jQuery对象和DOM对象的相互转化实现代码
2010/03/02 Javascript
jQuery 点击图片跳转上一张或下一张功能的实现代码
2010/03/12 Javascript
js Form.elements[i]的使用实例
2011/11/13 Javascript
两个listbox实现选项的添加删除和搜索
2013/03/01 Javascript
jquery text(),val(),html()方法区别总结
2013/11/04 Javascript
js 一个关于图片onload加载的事
2013/11/10 Javascript
Javascript中3种实现继承的方法和代码实例
2014/08/12 Javascript
js实现超简单的展开、折叠目录代码
2015/08/28 Javascript
JavaScript设置、获取、清除单值和多值cookie的方法
2015/11/17 Javascript
js操作table元素实现表格行列新增、删除技巧总结
2015/11/18 Javascript
Javascript BOM学习小结(六)
2015/11/26 Javascript
简单的JS轮播图代码
2016/07/18 Javascript
微信小程序 限制1M的瘦身技巧与方法详解
2017/01/06 Javascript
jQuery轻松实现无缝轮播效果
2017/03/22 jQuery
详解Vue中watch的详细用法
2018/11/28 Javascript
JavaScript forEach中return失效问题解决方案
2020/06/01 Javascript
Python编写Windows Service服务程序
2018/01/04 Python
深度学习入门之Pytorch 数据增强的实现
2020/02/26 Python
keras 如何保存最佳的训练模型
2020/05/25 Python
python 爬取英雄联盟皮肤并下载的示例
2020/12/04 Python
Python 实现RSA加解密文本文件
2020/12/30 Python
HTML5的语法变化介绍
2013/08/13 HTML / CSS
健康监测猫砂:Pretty Litter
2017/05/25 全球购物
CAD制图人员的自荐信
2014/02/07 职场文书
煤矿安全生产责任书
2014/04/15 职场文书
听课评语大全
2014/04/30 职场文书
2014年社区教育工作总结
2014/12/02 职场文书
css3实现背景图片颜色修改的多种方式
2021/04/13 HTML / CSS
MySQL日期时间函数知识汇总
2022/03/17 MySQL
零基础学java之方法的定义与调用详解
2022/04/10 Java/Android