我正在构建一个 MVC,其中一切都是模块。这将使我能够分离论坛和用户模块等对象的集合,以进一步组织我的 MVC。
/blog
/controller
/model
/view
/user
/controller
/model
/view
/forum
/controller
/model
/view
我目前将 forum/edit/34 之类的路由映射到包含 Forum_Controller_Edit 类的 /forum/controller/edit.php . (这与所有操作都是 Controller Forum_Controller::edit() 的方法的标准方法略有不同)。这允许我将所有单独的“操作”分开将 Controller 放入他们自己的文件中,这样我就不必通过 10 种不同的操作来管理大型 Controller 。
无论如何,这就是问题所在。假设我想向模块添加新 Controller 。例如,假设我想要论坛主题 (forum/topic/view/34)。我可以创建一个新的“主题”模块。
/forum
/controller
/model
/view
/topic
/controller
/model
/view
但是 1) 我将不得不使用像 /topic/view/ 这样的 URL 而不是 forum/topic/view, 2) 我将分离相关组件 (主题应该是论坛模块的一部分),并且 3)如果我愿意的话,我现在无法为内容节点之类的东西创建一个通用的“主题”模块。
那么,如何在每个模块中允许多个 Controller (具有多个操作)的同时构建模块化 MVC?
Kohana Framework决定实现一个 HMVC 来解决这个问题。但是,这会导致许多 is_file() 检查以找到您要加载的文件的正确位置。 I/O 检查在商品硬件上非常宝贵,所以我不认为这是一个选项。此外,加载的是哪个版本的类并不明显,这可能会导致在使用多个同名类时产生混淆。
我想找到一个解决这个问题的方法,它不涉及预先设置路径或检查正确类的文件夹。然而,在我查看的最近 20 个框架中,它们似乎没有很好地解决这个普遍问题。有人有什么想法吗?
如果我要实现路由,它会如何工作?我将如何处理第一层 (/forum)、第二层 (/forum/view) 和第三层 (/forum/topic/view)?我的路线如何知道第三级路线和带参数的第二级路线之间的区别?换句话说,我的系统会尝试执行其中哪些操作? (给定 URI“forum/topic/view/34”)
$controller = new \Forum\Controller\Topic\View;
$controller->action('34');
// or
$controller = new \Forum\Controller\Topic;
$controller->view('34');
// or
$controller = new \Forum\Controller;
$controller->topic('view', '34')
服用 Kyles advice我决定 ALL controllers 将需要一个路由集,这将允许我定义 URL 路径“forum/topic/view/34”路由之上的哪些类。毕竟,每个 URL 都很重要,不应基于您现有的文件系统结构。我相信他说 URL 设计比我们通常给予的更多关注是正确的。
最佳答案
I would like to find a solution to this problem that does not involve pre-setting paths
这称为路由,是解决方案。
of the last 20 frameworks I looked through they don't seem to have a good answer to this universal problem
通用解决方案是路由。
这正是框架使用它的原因。 路由是保留您的体系结构同时仍然具有 URI 灵 active 的方法。否则,您的 URI 命名将始终必须符合您的 MVC 布局。
关于php - 您如何在 MVC 中构造和路由模块?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5952290/
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"