当前位置: 首页 > news >正文

郑州云拓网站建设公司怎么在百度做宣传广告

郑州云拓网站建设公司,怎么在百度做宣传广告,wordpress微信管理,网站是谁做的原文链接#xff1a;https://blazor-university.com/dependency-injection/component-scoped-dependencies/owning-multiple-dependencies-the-right-way/拥有多个依赖项#xff1a;正确的方式在上一节[1]中#xff0c;我们看到了将多个拥有的依赖项注入组件的错误方法。本节…原文链接https://blazor-university.com/dependency-injection/component-scoped-dependencies/owning-multiple-dependencies-the-right-way/拥有多个依赖项正确的方式在上一节[1]中我们看到了将多个拥有的依赖项注入组件的错误方法。本节将演示解决问题的正确方法。如前所述OwningComponentBaseT 类组件将创建自己的依赖容器并在该容器中解析 T 的实例因此 T 的实例对于我们的组件是私有的。如果我们需要我们的组件私有地拥有多种依赖类型的实例那么我们必须做更多的工作。为此我们需要使用非泛型 OwningComponentBase 类。与通用版本一样此组件将创建自己的依赖容器该容器将在组件的生命周期内存在。但是它不会为我们实际解析任何依赖项而是让我们访问其依赖项容器以便我们可以解析我们需要的任何类型的实例。示例源代码[2]首先创建一个新的 Blazor 应用程序。然后就像我们之前所做的那样我们将创建一些可以注入的类这些类将使用状态成员来跟踪已创建的类实例的数量。创建以下接口public interface IOwnedDependency1 {public int InstanceNumber { get; } }public interface IOwnedDependency2 {public int InstanceNumber { get; } }然后创建实现这些接口的类。我将只显示第一类的代码第二类将是相同的。public class OwnedDependency1 : IOwnedDependency1 {private static volatile int PreviousInstanceNumber;public int InstanceNumber { get; }public OwnedDependency1(){InstanceNumber System.Threading.Interlocked.Increment(ref PreviousInstanceNumber);} }将接口 它们的实现类注册为 Scoped如果需要提醒您请参阅比较依赖范围[3]。接下来编辑 Index.razor 页面以便我们应用程序的用户可以通过单击复选框来切换组件。page /input idshow-component typecheckbox bindShowComponent / label forshow-componentShow component/labelif (ShowComponent) {MyOwningComponent / }code {bool ShowComponent  false; }当 ShowComponent 为 true 时我们的标记将创建 MyOwningComponent 的一个实例并渲染它。接下来我们将创建 MyOwningComponent。OwningComponentBase在 Shared 文件夹中创建一个名为 MyOwningComponent 的新 Razor 组件。我们将从 OwningComponentBase 中派生此组件。inherits OwningComponentBase然后创建一些类字段来保存依赖项。code {private IOwnedDependency1 OwnedDependency1;private IOwnedDependency2 OwnedDependency2; }解决拥有的依赖关系OwningComponentBase 创建的私有依赖性容器通过其ScopedServices 属性提供给我们。protected IServiceProvider ScopedServices { get; }我们可以使用这个 IServiceProvider 来解析组件所拥有的私有依赖容器中的依赖实例。inherits OwningComponentBase using Microsoft.Extensions.DependencyInjectiondivOwnedDependency1.InstanceNumber  OwnedDependency1.InstanceNumber /div divOwnedDependency2.InstanceNumber  OwnedDependency2.InstanceNumber /divcode {private IOwnedDependency1 OwnedDependency1;private IOwnedDependency2 OwnedDependency2;protected override void OnInitialized(){OwnedDependency1 ScopedServices.GetServiceIOwnedDependency1();OwnedDependency2 ScopedServices.GetServiceIOwnedDependency2();} }第 1 行从 OwningComponentBase 继承来给我们自己的私有依赖容器。第 2 行使用 DependencyInjection 命名空间因此我们可以在 IServiceProvider 上使用 GetServiceT 扩展方法。第 19 21 行使用 OwningComponentBase.ScopedServices 属性来解析组件所需的依赖项实例。第 6 9 行显示为我们创建的依赖项的实例号。运行示例如果我们运行示例应用并勾选复选框我们将看到以下输出。OwnedDependency1.InstanceNumber 1OwnedDependency2.InstanceNumber 1取消勾选该复选框以允许删除我们的组件然后再次勾选该复选框以让 Blazor 创建 MyOwningComponent 的新实例。渲染输出现在应该如下所示。OwnedDependency1.InstanceNumber 2OwnedDependency2.InstanceNumber 2这表明每次创建组件时我们在组件的 OnInitialized 方法中解析的两个依赖项都是新的实例。依赖生命周期OwningComponentBase 类实现 IDisposable 接口。当从OwningComponentBase 派生的任何组件不再呈现时Blazor 将在 OwningComponentBase 上执行 Dispose 方法。组件上的 Dispose 方法将对其拥有的私有依赖项容器调用Dispose。反过来该容器创建的任何实现 IDisposable 的对象实例也将执行其 Dispose 方法。要演示这种行为请对应用程序进行以下更改。首先在我们的组件上重写 Dispose(bool isDisposing)并让它在被释放时输出日志。public void Dispose() {System.Diagnostics.Debug.WriteLine(Disposing   GetType().Name); }然后对于我们的每个依赖类OwnedDependency1 和 OwnedDependency2让它们实现 IDisposable并且再次让它们在执行 Dispose 时输出日志。public class OwnedDependency1 : IOwnedDependency1, IDisposable{... Other code omitted for brevity ...public void Dispose(){System.Diagnostics.Debug.WriteLine($Created {GetType().Name} instance {InstanceNumber});}}我们还可以在类的构造函数中添加一些日志记录。现在运行应用程序并切换复选框将输出类似于以下内容的日志文本。Created MyOwningComponentCreated OwnedDependency1 instance 1Created OwnedDependency2 instance 1Disposing OwnedDependency2 instance 1Disposing OwnedDependency1 instance 1Disposing MyOwningComponentCreated MyOwningComponentCreated OwnedDependency1 instance 2Created OwnedDependency2 instance 2Disposing OwnedDependency2 instance 2isposing OwnedDependency1 instance 2Disposing MyOwningComponent结论当您的组件只需要拥有一个依赖项时从 OwningComponentBaseT 派生当您的组件需要拥有多个依赖项时从非泛型 OwningComponentBase 派生。尽管解析组件依赖项实例的过程是一个手动过程但不需要处理任何创建的依赖项因为组件的依赖项容器将在 OwningComponentBase.Dispose 时处理它们。参考资料[2]源代码: https://github.com/mrpmorris/blazor-university/tree/master/src/DependencyInjection/OwningMultipleDependenciesTheRightWay
http://www.huolong8.cn/news/169564/

相关文章:

  • 哪些公司做外贸网站wordpress邮箱非必填
  • 娄底网站建设开发豪华大气的旅行社网站源码
  • 做快三网站莱西建设局官方网站
  • h5网站不利于优化吗手机原理网站
  • 重庆 网站定制网站开发遵循的标准或规范
  • 网站做网站词怎么推广上海市建设网站
  • 网站建设公司选哪个好上海自主建站模板
  • 展示网站动画怎么做的网络营销网站推广
  • 网站链接怎么做天津公司网站建设
  • 孝感网站建设孝感公司网站建设系统
  • 沈阳手机网站开发wordpress 评论加星
  • 网站设计论文开题报告淘宝运营招聘
  • 网站开发是什么职业实验室规划设计厂商
  • c 怎么和网站做交互wordpress 动态主题
  • 上海东道设计深圳市seo网站设计多少钱
  • 电子商务网站建设的方法什么后台做网站安全
  • 深圳移动网站建站网站服务器关闭怎么恢复
  • 网站开发网站页面沈阳网站建设公众号
  • 安徽省建设信息网站广州电子商城网站建设
  • 关于我们网站设计pc端网站开发总结
  • 网站优化自已做还是请人做营销公司排行
  • 苏州互联网企业东莞seo站内优化
  • 培训网站开发哪个好新余网站开发
  • 仿别人的网站违法嘛制作网站需要哪些技术
  • 企业做网站被骗百度网盘官网登录入口
  • 福州企业网站维护noscript wordpress
  • 郑州网站建设哪家公司便宜目前比较火的电商平台有哪些
  • 一级做a爱免费网站新手如何找cps推广渠道
  • 安卓手机app开发教程跟我学seo
  • 长沙做网站的公司对比wordpress 调用内容代码