jjzjj

javascript - 非常大的单页应用程序设计问题

coder 2024-07-17 原文

我目前正在编写一个非常非常大的单页 web/javascript 应用程序。

我使用的技术是 ASP.NET MVC4、jquery、knockout.js 和 amplify.js。

我遇到的问题是,大多数(如果不是全部的话)单页应用程序示例都是针对较小的应用程序的,其中所有脚本模板(无论是 jquery、handlbars 等...)都在同一个文件中与其余的 html 代码。这适用于较小的应用程序,但我正在构建的应用程序是一个完整的维护物流应用程序,有很多很多屏幕。

到目前为止,我采用的方法是我有一个外壳(我的主要 index.cshtml 文件),并且我正在使用 jquery 的 load() 方法来加载或更确切地说是在用户进行特定选择时注入(inject)我需要的特定文件。

例子:

function handleLoginClick(){

    App.mainContentContainer.delegate('#btnLogin', 'click', function() {

        App.loadModule('Home/ProductionControlMenu', App.MainMenuView.render());

    });

}

这是 App.loadModule 函数的代码:

App.loadModule = function(path, callback){

    App.mainContentContainer.load(App.siteRoot + path, callback);

};

一切都很顺利,直到我需要真正开始与新加载的屏幕上的各种表单元素进行交互。 jquery 似乎无法直接处理它们。我不能使用 .live() 或 .delegate(),因为它们不是事件,它们是文本框和按钮,有时我需要更改它们的 css 类。

我发现他们唯一的方法是从外壳获取元素的句柄(不是通过 .load() 加载的东西)并使用 jquery 的 .find() 方法,如下所示:

  App.mainContentContainer.find('#btnLogin').addClass('disabled');

很明显,我不想每次需要与表单元素交互甚至从表单元素中检索值时都做这样的事情。

有没有人知道我如何创建一个可维护的非常大的单页应用程序,其中可能有数百个 .html 文件,而不必将所有 html 代码放在一个文件中,并且仍然绕过这个 .load()我有什么问题?

如有任何想法,我们将不胜感激。 :-)

V/R

克里斯

更新

我想我应该发布一个更新,以及关于事情进展如何和有效的方法。经过大量研究,我决定使用 Google 的 AngularJS Javascript 框架。它以指数方式简化了考验,我绝对会建议所有正在考虑制作大型 SPA 的人看一看。

链接:

主站 http://angularjs.org/

Angular 上很棒的免费短视频: http://www.egghead.io/

最佳答案

这实际上是一个非常复杂的问题,因为它实际上涉及到您的架构设计。

对于大型单页应用程序,最好使用某种前端 MV* 风格的框架,例如 backbone.js ,它非常有用地与 jQuery 联系在一起。您还应该考虑使用某种依赖管理框架,例如 require.js为了异步加载您的脚本和依赖项,甚至更好——在您的应用程序设计中使用 AMD 模式,使您的架构模块化并更易于管理。

就这与您的 MVC4 项目的关系而言,您有一些选择:

  1. 您是否想将 MVC 用作某种“服务层”,它只返回 JSON 对象,允许您的前端创建标记/模板(想想 handlebars.js ),或者
  2. 您是否希望 MVC 项目返回部分 View (HTML) 作为响应,您可以在其中利用 Razor 模板系统并仅使用前端来显示从服务器返回的内容?

无论哪种方式,您都必须想出一种方法来处理前端事件和导航(backbone 在与 jQuery 结合使用时提供这两种功能)。更复杂的是您选择将另一个 View 的事件通知一个 View 的模式(有很多方法可以做到这一点)——例如发布/订阅模式。

我希望我有所帮助,我知道我没有完全回答这个问题,但答案可能会很长!

关于javascript - 非常大的单页应用程序设计问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13729788/

有关javascript - 非常大的单页应用程序设计问题的更多相关文章

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  3. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  4. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  5. ruby - 通过 rvm 升级 ruby​​gems 的问题 - 2

    尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub

  6. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  7. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  8. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  9. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  10. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

随机推荐