赛普拉斯 - 拖动&滴 - 角CDK
简单地实现了Angular CDK Drag&掉落,用柏树。 具有所有包装的最新版本,所有问题&解决方案围绕着工作。
基本上,拖动&掉落夏娃。
用
- 即使在stackoverflow上的这个“解决”问题的答案如何实现柏树测试中的拖放?
,但无效。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
当我们发现问题时,我们设法找到解决方案。
简而言之,问题是,在最新版本中,Angular材料 - CDK阻止了屏幕阅读器的“拖放”,以供访问性。没关系,问题在于库 /解决方案已发布,它们被视为“屏幕读取器”,因为“按钮”为0。
在某些情况下,仅通过提供“按钮= 1”就足够了,但这不是我们的情况。
因为我们的情况是一个复杂的阻力&掉落的地方,您只能从“句柄”中拖动,并且在列表的区域中会受到限制(因此仅在Y轴上移动)这些解决方案将行不通。
唯一到目前为止对我们有用的最佳解决方案是以下一个:
使用柏树插件 cypress-real-events
When we found the problem, we manage to find the solution.
In a nutshell, the problem is that angular material - cdk, in latest versions, they are blocking the "drag and drop" from screen readers, for accessibility purposes. Which is ok, the problem is that the library / solutions posted, they were considered as "screen readers" as the "buttons" was 0 in the event.
In some of the cases, just by providing the "buttons = 1" would be enough, but that wasnt our case.
Because our case was a complex Drag & Drop where, you could only drag from the "handle" and you would be limited in the area of the list (so only move in Y axis) these solutions would not work.
The only & best solution that worked for US so far has been the following one:
Using the cypress plugin cypress-real-events
mmonteirocl 提供的解决方案也对我来说也很好。 其实现为自定义命令。
我在我们的命令中将
The solution provided by mmonteirocl above worked perfectly for me as well. I implemented it as a custom command in our commands.js:
Then called it the test like:
使用拖放占位符而没有任何其他库时,我可以正常工作。我不清楚为什么我必须这样写,但似乎有效。
I got it working when using drag placeholder without any additional library. I'm not clear on why I have to write this way but it seems to work.
这个具有角材料CDK拖动的工人
this worker for Angular material cdk drag and drop