专栏首页Google DartAngularDart Material Design 弹出框 顶

AngularDart Material Design 弹出框 顶

MaterialPopupComponent

Selector: <material-popup>

具有材料设计外观的弹出组件。

注意事项:

  • 弹出窗口关闭和打开会自动延迟以添加动画
  • 利用PopupInterface中定义的enforceSpaceConstraints。

如果内容大小太多添加滚动到页面,这将非常有用。

  • 即使此组件支持ChangeDetectionStrategy。对于在示例中测试的案例的OnPush,它没有设置ChangeDetectionStrategy。这意味着可以在OnPush模式下在另一个组件中使用此组件,但由于任何此类实现都需要所有内容子项支持OnPush,因此由实现者自行决定。
  • 如果内容发生变化并需要重新调整位置,请使用在PopupInterface中也定义的trackLayoutChanges。

材质弹出窗口还支持延迟/延迟加载的内容。

该组件将自己发布为DropdownHandle,因此其子级可以通过注入来控制其可见性:

class MyComponent {
  final DropdownHandle _dropdownHandle;

  MyComponent(this._dropdownHandle);

  void onSomethingThatShouldCloseTheDropdown() {
    _dropdownHandle.close();
  }
}

Inputs:

  • autoDismiss bool   设置弹出窗口是否应在文档按下时关闭(关闭)自身。
  • constrainToViewport bool  设置是否应将弹出窗口限制为视口。 如果这是true,那么弹出窗口的位置将被限制为始终位于视口内而不是移出屏幕外。
  • enforceSpaceConstraints bool  设置弹出窗口是否应根据相对于视口的可用空间自动重新定位自身。
  • hasBox bool 弹出式面板是否具有包装内容的封闭框。 这为面板提供了阴影和背景颜色。当它关闭时,不会应用延迟动画。
  • ink bool  将弹出窗口的背景颜色设置为墨迹($ mat-gray-700)。
  • matchMinSourceWidth bool  设置弹出窗口是否应将最小宽度设置为源宽度。
  • offsetX int  将x偏移设置为弹出窗口最终定位的位置。
  • offsetY int  将y偏移设置为弹出窗口最终定位的位置。
  • popupSizeProvider PopupSizeProvider  为弹出窗口大小设置提供程序。 覆盖注入的PopupSizeProvider。
  • preferredPositions Iterable<dynamic> 设置在设置enforceSpaceConstraints时应尝试的位置。 与Angular提供程序类似,它支持首选位置的嵌套列表。 弹出窗口将展平位置列表并选择第一个适合屏幕的位置。
  • slide String  弹出缩放的方向。 有效值为x,y或null。
  • source PopupSource  设置应相对于弹出窗口创建的源。
  • trackLayoutChanges bool  设置是否应跟踪源以进行更改。
  • visible bool  设置是否应显示弹出窗口。 如果可见不是当前状态,则可以关闭或打开弹出窗口。
  • z int  边界效果的z-elevation。

Outputs:

  • autoDismissed Stream<Event>  弹出窗口自动关闭时触发事件的流。 输出事件应该是FocusEvent或MouseEvent。
  • close Stream<void>  关闭弹出窗口时触发异步事件。
  • open Stream<void>  在打开弹出窗口时触发异步事件。
  • opened Stream<void>  弹出窗口打开后触发事件的流。
  • visibleChange Stream<bool>  弹出窗口的visible属性发生更改时触发的同步事件(例如,从false变为true或true变为false)。 与onOpen和onClose不同,这在事件完成后发生。

MaterialPopupExample

查看示例,查看源码

(adsbygoogle = window.adsbygoogle || []).push({}); function googleAdJSAtOnload() { var element = document.createElement("script"); element.src = "//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"; element.async = true; document.body.appendChild(element); } if (window.addEventListener) { window.addEventListener("load", googleAdJSAtOnload, false); } else if (window.attachEvent) { window.attachEvent("onload", googleAdJSAtOnload); } else { window.onload = googleAdJSAtOnload; }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • AngularDart Material Design 工具提示 顶

    工具提示卡的目标可以是任何元素,例如按钮,输入,链接等。目标也可以是help_outline图标,其充当实际目标的代理。

    南郭先生
  • Dart服务器端 shelf_rest包 原

    shelf_rest是shelf_route的一个替代品。 它支持shelf_route的所有功能,增加了很多功能以减少样板。

    南郭先生
  • 多线程实现方式 转

    进程是程序在处理机中的一次运行。一个进程既包括其所要执行的指令,也包括了执行指令所需的系统资源,不同进程所占用的系统资源相对独立。所以进程是重量级的任务,它们之...

    南郭先生
  • Android-Handler机制

    参考:https://mp.weixin.qq.com/s/AvpOq6eh-IBDJj2SXa_wXw https://www.jianshu.com/p/...

    android_薛之涛
  • WPF效果第一百五十八篇之使用委托优化代码

    看到需求很明确:控件替换;也就是他在主窗口定义了个替换的方法,然后要在子窗口的拖放(Drop)事件去触发;上面的写法真是牛啊,别的不说咱基本的提取通用方法不会吗...

    WPF程序员
  • 3.4.4 多帧滑动窗口与选择重传协议(SR)

    为了进一步提高信道的利用率,可设法只重传出现差错的数据帧或者是计数器超时的数据帧。但此时必须加大接受窗口,以便先收下发送序号不连续但仍处在接受窗口中的那些数据帧...

    week
  • 极客工具,PDF合并工具

    这两天一番花两天的时间,重新用python和python图形化开发工具tkinter,完善了下PDF合并小工具,终于可以发布了。

    efonfighting
  • 快速了解TCP的流量控制与拥塞控制

    数据的传送过程中很可能出现接收方来不及接收的情况,这时就需要对发送方进行控制以免数据丢失。利用滑动窗口机制可以很方便地在TCP连接上对发送方的流量进行控制。TC...

    全菜工程师小辉
  • 【程序源代码】IntelliJ IDEA 破解版

    今天给大家带来一套《IntelliJ IDEA 破解版》;好多小伙伴想用但正式版本是收费的。所以结合咱们国家的国家能为破解版的绝对破解。所以今天教大家安装并破解...

    程序源代码
  • Shell的基础介绍和案例

    L宝宝聊IT

扫码关注云+社区

领取腾讯云代金券