创建将由桌面应用程序和网站使用的对象模型时,我应该考虑哪些特殊注意事项?

发布于 2024-09-16 08:29:46 字数 342 浏览 5 评论 0原文

我正在 C#.Net 中编写一个工具,该工具将用于生成用户可以浏览的内容目录。最初我正在创建一个基于 WinForms 的界面,但将来我也希望能够创建一个基于 Web 的界面。因此,我一直小心地将接口概括为目录,以便它不依赖于特定的 UI。

我唯一的 Web 开发经验是在 90 年代初创建自己的 HTML 网站,并且我编写了一些 ASP(不是 ASP.NET)。现在,有了 ASP.NET,我似乎能够利用现有的 C#.Net 对象模型来创建 Web 基础界面。但除了简单的 hello world 示例之外,我确实没有使用 ASP.NET 做过任何事情。

在设计对象模型时是否应该考虑任何特殊事项,以便稍后我可以为其创建 Web 界面?

I'm writing a tool in C#.Net that will be used to generate Catalogs of content which users can browse. Initially I am creating a WinForms based interface, but in the future I'd like to be able to create a web based interface as well. So I've been careful to generalize the interface to a Catalog so that it does not depend on a specific UI.

My only experience with web development has been creating my own HTML website back in the early 90's, and I've done a little ASP (not ASP.NET). Now with ASP.NET it seems that I should be able to leverage my existing C#.Net object model, to create a web base interface. But I really hasn't done anything with ASP.NET beyond a simple hello world example.

Are there any special considerations I should make in designing my object model so that later I can create a web interface to it?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

思慕 2024-09-23 08:29:46

以下是需要遵循的几件事:

  1. 您应该打包您的对象模型
    是单独的项目(您需要
    无论如何都要分享它
    不同的项目)并确保
    您不添加特定的
    对它的引用(例如,不要
    添加 System.Web、WinForms、WPF 等)-
    这将自动避免任何
    不需要的依赖项。
  2. 尽量让你的课程精简。避免跟踪更改状态等的类 - 在 Web 场景中,跟踪多个请求的状态是昂贵的。因此,最好让您的对象仅携带数据。
  3. 考虑您的对象可能需要序列化和/或通过线路传递的可能性。例如,为 Windows 和 Windows 提供服务的中间件服务。网络客户端。或者在视图状态下存储对象的网页。

Here are few things to follow:

  1. You should package your object model
    is separate project (that you need
    to do anyway to share it among
    different projects) and make sure
    that you do not add specific
    references to it (for example, don't
    add System.Web, WinForms, WPF etc) -
    this will automatically avoid any
    unwanted dependencies.
  2. Try to have your classes as lean as possible. Avoid classes that track change states etc - in web scenario, tracking state over multiple requests is expensive. So it's best to have to your objects carry data only.
  3. Consider the possibility that your objects may need to be serialized and/or passed over a wire. For example, a middle ware services serving both windows & web client. Or web page storing the object in the view-state.
以酷 2024-09-23 08:29:46

其实不应该有那么大的区别。

请小心不要在实体类中放置过多的“智能”。这是我在 Windows 应用程序中经常看到的模式。不要在项目中要为 Web 应用程序重用的部分中引用特定于 Windows 窗体开发的控件。

存储库模式适用于 Windows 和 Web 应用程序,因为您通常希望针对多个用户的性能以不同方式优化 Web 应用程序。

There really shouldn't be that big a difference.

Be careful about placing too much “intelligence” in your entity classes. That’s a pattern I’ve seen often in Windows apps. Don't make references to controls that are specific to Windows Forms development in the parts of your project that you want to reuse for the web application.

Repository patterns work well with both Windows and Web applications, because you often want to optimize the web apps differently for performance with multiple users.

寂寞清仓 2024-09-23 08:29:46

您的要求可以通过多层架构来处理:

http://en.wikipedia.org/wiki/多层架构

Your requirement can be handled with a multi-tier architecture:

http://en.wikipedia.org/wiki/Multitier_architecture

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文