微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

用 ViewEncapsulation.ShadowDom 元素包裹的元素内 cdkScrollable 和 cdkDropList 的问题

如何解决用 ViewEncapsulation.ShadowDom 元素包裹的元素内 cdkScrollable 和 cdkDropList 的问题

我在使用带有 encapsulation: ViewEncapsulation.ShadowDom 元素的元素包裹的 cdkScrollable 容器中使用 cdk 拖放功能时遇到问题。

当拖动元素导致列表滚动时,滚动偏移量不会被添加到拖动元素定位中。

enter image description here

wrapper.component.html

@Component({
  selector: 'wrapper',...
  encapsulation: ViewEncapsulation.ShadowDom,})
export class WrapperComponent {}

app.component.html

<wrapper
    <div class="container" cdkScrollable>
        <div class="list" cdkDropList>
            <div *ngFor="let question of questions" class="question__container" cdkDrag>
                <div class="question__content">{{ question?.Name }}</div>
            </div>
        </div>
    </div>
</wrapper>

app.component.css

.container {
  height: 500px;
  overflow-y: auto;
}

.question {
  &__container {
    padding: 10px;
    border: 1px solid black;
  }
}

现在,当我注释掉 <wrapper></wrapper> 时,一切都按预期进行。拖动 cdkDrag 时滚动效果很好。

enter image description here

有什么办法可以解决这个问题吗?正如我在 Scrolldispatcher 中看到的那样,它注入 DOCUMENT 并将其用作滚动计算的根。这可能是问题的根源吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?