这听起来像是您希望随着角度应用程序的增长逐渐减少对 CodeIgniter (CI) 路由的使用。这并不难,但需要很多细节。哪种方法有效取决于您的项目结构。注意:我从代码点火器URL中删除了索引.php,因此下面的路径可能与默认值不同。
1)代码标志安装在根目录
如果 CI 安装在服务器的根目录上,则可以在 CI 中创建一个文件夹(例如,我有一个“ng”文件夹)。您的项目将如下所示:
/controllers
/models
/ng
(etc)
/index.php (code igniter index file)
将 .htaccess 文件放在其中,其中包含以下内容:/ng
Order allow, deny
Allow from all
这允许直接访问其中的文件,而不是通过CI的路由系统将这些请求发送回去。例如,您现在可以直接加载它:/ng
example.com/ng/partials/angular-view.html
主网页仍将由CodeIgniter创建,但它现在可以包含Angular资源,例如部分视图等。最终,您可以通过返回一个简单的页面来替换CodeIgniter正在做的大部分工作,并让Angular加载部分视图,就像它的设计一样。/ng
此方法很好,因为CodeIgniter可以控制是否加载初始页面(通过CI控制器中的一些用户身份验证代码)。如果用户未登录,则会重定向他们,并且永远不会看到 Angular 应用。
2) CodeIgniter in Directory
如果 CI 安装在某个目录中,例如,您只需在其旁边创建一个目录,example.com/myapp/(code igniter)
example.com/myappNg/
/myapp/
/myapp/controllers/
/myapp/models/
/myapp/(etc)
/myapp/index.php (code igniter index file)
/myappNg/
/myappNg/partials/
/myappNg/js/
/myappNg/(etc)
现在,在 Angular 应用程序中,您可以通过创建相对于域根目录(而不是相对于 Angular 应用)的路径,从 CI 请求资源。例如,在Angular中,您将不再从 Angular文件夹请求部分视图,而是希望从CI请求视图。请注意前导 。“someResource”可以返回一个html文档,或JSON或你首先使用Code Igniter所做的任何事情。partials/angular-view.html
/myapp/someResource
/
最终,您可以替换引用 的路径数。一旦您不再将CI用于任何内容,您只需将Angular索引放入.html,它将继续引用您在./myapp/
/myapp/
/myappNg/
TL;DR 使您的 Angular 应用程序完全可用,并将其与 CodeIgniter 分离。逐渐转向使用Angular分视图和其他JSON源,而不是链接到CodeIgniter页面。最终将 CodeIgniter 端点替换为引导 Angular 的 HTML 文件。