如果这是一个“duh”问题或者如果您需要更多信息来回答,请原谅我,我是 CodeIgniter 的新手,仍然没有弄清楚一些最佳实践等......
在 routes.php
我有 $route['default_controller'] = "home";
所以我的 default_controller
显然是“home” .
在我的 home.php
Controller 中,我有:
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Home extends CI_Controller {
function __construct() {
// blah
}
function index(){
// blah
}
function login(){
// blah
}
}
哪个工作正常,一切都没有问题。我唯一想不通的是,如果我想访问 login
功能,我目前必须去 www.blah.com/home/login。 我怎样才能改变它,让它直接转到 www.blah.com/login,而无需创建新的 Controller (我想将其中一些一次性基准 url 全部保留在我的默认值中 Controller )?这是可能的还是我只需要创建一个新的 Controller ?
如果我只需要创建一个新的,是否有关于您拥有多少个 Controller 等的最佳实践
最佳答案
文档说:如果 URL 中提供的 URI 段无法与有效路由匹配,此路由将告诉路由器使用哪些 URI 段。
所以使用$route['login'] = 'home/login';
关于php - CodeIgniter "default_controller"函数在 URL 中没有 Controller 名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13705604/
谁能解释一下这个表达式。似乎两者相同,但实际上并非如此。a||a=bora||=b和a=a||b如果a=4和b=6,输出总是4这总是让我感到困惑和误解。有人可以解释一下吗? 最佳答案 a||a=b如果a为真,则查找a,返回a,否则a=b完成,即你将b的值赋给a。a=a||b这是一个赋值操作。在这里,您正在为a赋值,而不管它持有什么值。所以a等于a||b。在语句的第二部分,您正在寻找a。如果它的值是真值,则将其赋值回a本身,否则将b的值赋给a。长话短说a=a||b正在为a分配一个值(取决于条件),而不管它持有什么值。a||=b如果已经
我有两个数组,一个包含数据,一个包含索引。我想知道是否有一些好的方法可以删除indexes中给定位置的data中的元素。我可以做简单的迭代,但我想知道最短的方法是什么:data=['a','b','c','a','b','c','a','b','c']indexes=[2,5,8]//somecodeheredata中的元素在索引恰好与数组索引中的数字重合时消失。它应该看起来像这样:['a','b','a','b','a','b'] 最佳答案 data.values_at(*data.each_index.to_a-indexes)
例如,要返回我可以写的第10,000个质数:require'prime'Prime.first(10000).last#=>104729但是创建一个巨大的中间数组,只是为了检索它的最后一个元素感觉有点麻烦。鉴于Ruby是一种如此优雅的语言,我本以为会是这样的:Prime.at(9999)#=>104729但是没有Enumerable#at。上面的解决方法是有意的还是有更直接的方法来获取Enumerable的第n个元素? 最佳答案 我能想到的与假设的at方法最接近的是drop,它会跳过指定数量的元素。它试图返回一个实际的数组,所以如果
假设我有一个通用的Proc、Lambda或method,它带有一个可选的第二个参数:pow=->(base,exp:2){base**exp}现在我想柯里化(Currying)这个函数,给它一个3的exp。cube=pow.curry.call(exp:3)这里有一个歧义,由关键字参数和新的散列语法引起,Ruby将exp:3解释为作为第一个参数传递的散列,base.这导致函数立即被调用,当#**被发送到散列时呈现NoMethodError。为第一个参数设置默认值同样会导致函数在柯里化(Currying)时立即被调用,如果我将第一个参数标记为必需,而不提供默认值:pow=->(base:
我需要转换CSV文件中的哈希数组。我发现的各种方法涉及在数组中插入哈希值:classArraydefto_csv(csv_filename="hash.csv")require'csv'CSV.open(csv_filename,"wb")do|csv|csv不幸的是,这个方法要求数组中的每个元素都是完整的,例如,当我有这个数组时,它甚至不会返回有效的csv:myarray=[{foo:1,bar:2,baz:3},{bar:2,baz:3},{foo:2,bar:4,baz:9,zab:44}]我正在寻找一种创建csv的方法,它可以找到所有可能的header,并以正确的顺序分配值,并
我正在探索Sinatra,我想使用session,但我不想将它们存储在Cookie中,我发现Rack::Session::Pool效果很好。现在我希望session在一定持续时间后过期,但我不明白如何实例化Rack::Session::Pool并且他们在Sinatra中使用它。有什么线索吗? 最佳答案 Sinatra非常强大,TheWickedFlea的技巧没有奏效,但这个确实奏效了:useRack::Session::Pool,:domain=>'example.com',:expire_after=>60*60*24*365谢谢
我一直在努力更好地理解Ruby,但我遇到了一些问题:$SAFE=1puts$SAFE#1proc{$SAFE=2puts$SAFE#2}.callputs$SAFE#1以上代码部分取自eRB的源代码并重写以更好地突出示例。基本上在proc中,可以将$SAFE的值设置为任何想要的值,并且在proc之后,SAFE的值返回到它在proc之前的值。如果我不使用单词$SAFE,而是将其更改为不同的单词,例如$DOOR:$DOOR=1puts$DOORproc{$DOOR=2puts$DOOR}.callputs$DOOR那么$DOOR在proc之后的值是2而不是1。为什么两个例子有区别?
我最近玩过IronRuby,但我也想安装引用实现。不用说,我是Ruby的菜鸟,所以我有一个非常愚蠢的问题。关于RubyForgedownloadpage,Ruby安装程序(适用于Windows)共有三种不同的最终版本:rubyinstaller-1.8.6-p398.exerubyinstaller-1.8.7-p249.exerubyinstaller-1.9.1-p378.exe我不明白怎么会有三个不同的最终版本。我能理解有一个1.8版本和一个1.9版本,但为什么我只能在1.8.6和1.8.7之间选择?我真正想知道的是哪个版本是“最好的”?如果答案是“1.9.1”,为什么要选择1.
这个让我抓狂。我可以通过irb加载gem:steve@server:/var/www/listings$irbirb(main):001:0>Gem.path=>["/home/steve/.gem/ruby/1.9.1","/usr/local/ruby/lib/ruby/gems/1.9.1"]irb(main):002:0>require'nokogiri'=>true但我无法通过Rails控制台加载它:irb(main):001:0>Gem.path=>["/home/steve/.gem/ruby/1.9.1","/usr/local/ruby/lib/ruby/gems/1
我对它的返回方式感到困惑:defutc2user(t)ENV["TZ"]=current_user.time_zone_nameres=t.getlocalENV["TZ"]="UTC"resend它首先设置ENV变量,然后将'res'设置为本地值,然后重新分配ENV变量,然后返回res?不确定我是否理解这是如何从UTC转换为用户时区的? 最佳答案 第一行是将环境时区变量设置为用户的时区,以便在正确的时间为该用户获取res值。如果它没有设置为用户的,时间仍将是UTC。然后它将环境变量设置回UTC时间,我假设这是应用程序的默认时间。然