CI框架与Thinkphp框架的一些区别

CI框架与Thinkphp框架的一些区别

大家好,又见面了,我是全栈君。

system             是框架核心

application        是项目目录

index.php          是项目入口文件

其他目录可以删除

 

控制器命名规则

 

控制器不加 Controller 后缀,

如 user.php 这就是一个控制器

 

 

 

修改默认控制器和方法

 

默认控制器是welcome.php,不喜欢可以改掉。

修改方法如下:

在 config/routes.php 中

$route[‘default_controller’] = ‘welcome’;

改为

$route[‘default_controller’] = ‘index/home’;

 

为什么不该成“index/index”呢???

因为CI中的控制器命名中没有后缀,所以index类的index方法会默认为析构方法__construct();

所以不可以这样搞,如果改成”index/index”则index方法会被调用两次。

 

加载视图文件

 

$this->load->view(‘index/home’);

这个视图文件放在/application/view/index/home.php

看到这个文件的后缀了吗?它是一个php文件,不是html文件

 

在CI中 view() 方法可以使用多次,也就是可以加载多个模板

可以这样写:

 

1.在 /application/view/index目录下有这样几个模板文件

    header.php

    main.php

    footer.php

 

2.在index控制器的home方法中

public 
function 
home(){
    
//按顺序加载模板文件
    
$this
->load->view(
'index/header'
);
    
$this
->load->view(
'index/main'
);
    
$this
->load->view(
'index/footer'
);
}

 

给模板分配变量

 

CI框架中的模板是直接写php代码的,如分配一个hello的变量:

$this->load->vars(‘hello’,’heheheh’);

在模板中直接写 <?php echo $hello;?>变量将变量输出。

还可以这样:

$data[‘hello’] = ‘hello xxoo—‘;

直接写入关联数组

$this->load->vars($data);

在模板中关联数组健名就是模板里的变量名

 <?php echo $hello; ?>

 

CI超级对象($this)中的装载器load

 

文件在system/core/loader.php,被实例化成一个属性

$this->load 属性是经常用到的,这里有几个常用的方法

    $this->load->view()

    $this->load->vars()

    $this->load->database()

    $this->load->model()

还可以这样写

$data
[
'one'
] = 
'one'
;
$data
[
'two'
] = 
array
(1,2,3,4,5);
//加载模板并分配变量
$this
->load->view(
'user/user'
,
$data
);

 

获取url中的参数$this->uri

文件在system/core/URI.php

如:url为 localhost/CodeIgniter/index.php/index/home

echo $this->uri->segment(1);

输出为:index

还可以这样

url为:http://localhost/CodeIgniter/index.php/index/home/1

public function home($id){

echo $id;

}

输出 1

多个参数同样,只不过顺序有限制

 

输入对象 $this->input

类文件目录同上

    $this->input->post(‘username’);//同$_POST[‘username’];

    $this->input->server(‘HTTP_REFERER’);//同$_SERVER[HTTP_REFERER”]

 

    

$this在视图中也可以使用

 

 

 

关于数据库的操作

 

pdo设置

在application/config/database.php 中找到并填写成如下:

$db[‘default’] = array(

    ‘dsn’=> ‘mysql:host=localhost;dbname=test;port=3306’,

    ‘hostname’ => ”,

    ‘username’ => ‘root’,

    ‘password’ => ‘123456’,

    ‘database’ => ”,

    ‘dbdriver’ => ‘pdo’,

);

// 设置默认加载的数据库的配置

$active_group = ‘default’;

$query_builder = TRUE;

 

// 这个数组可以有多个,不同数据库填写不同数组名称

$db[‘default’] = array(

);

 

$db[‘hello’] = array(

);

从数据库中获取数据

public 
function 
home(){
     
    
// 1.转载数据库操作类
    
$this
->load->database(
'default'
);
//默认为default可以不写
     
    
$sql 

"select id,title from article limit 10"
;
    
// 2.执行sql
    
$obj 

$this
->db->query(
$sql
);
     
    
// 3.获取结果集
    
$data 

$obj
->result();
     
    
echo 
"<pre>"
;
    
var_dump(
$data
);
     
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112280.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 递归下降算法_递归下降分析程序得到的经验

    递归下降算法_递归下降分析程序得到的经验递归下降算法算法模型:Term=Term+ExprExpr=Expr+FactorFactor=单个元素。最小单位。 实现原理:一个程式进入算法及被看作是一个项,分解成项加表达式的形式,表达式被分解成表达式加因子的形式,因子是这个算法中的最小单位。上一级调用比自己小一级的自己。这里三层分离,越下层模型中所形成的优先级就会越高。 我用递归下降算法写了个简单的计算器,递归算法为我的运算符号…

    2022年4月20日
    78
  • 解决vscode中文乱码的代码_vscode终端

    解决vscode中文乱码的代码_vscode终端我们现在很多编程开放工作中,VSCode已经成了一款难以绕过去的轻量级完善好用的代码编辑器。功能完善兼容性好体验不错,受到越来越多的开发者的认可。所以涉及到编程工作,VScode的安装是个必备的准备工作。我们本文就介绍下Windows和Ubuntu这样的Linux两个操作系统下安装VScode编辑器并解决打开代码文件的时候其中中文显示乱码的问题。当然Windows版本的VScode安装很简单,我们…

    2022年9月2日
    3
  • Html学习笔记3

    Html学习笔记3

    2022年2月7日
    36
  • 帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)

    帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)  作为一名前端工程师,必须搞懂JS中的prototype、__proto__与constructor属性,相信很多初学者对这些属性存在许多困惑,容易把它们混淆,本文旨在帮助大家理清它们之间的关系并彻底搞懂它们。这里说明一点,__proto__属性的两边是各由两个下划线构成(这里为了方便大家看清,在两下划线之间加入了一个空格:__proto__)。  现在正式开始!让我们从如下一个简单的例…

    2022年7月23日
    12
  • 2020/7/7学习记录

    2020/7/7学习记录1.微信小程序text内容显示空格<text decode=”{{true}}”space=”{{true}}”>报名人数&nbsp;</text>decode=”{{true}}”space=”{{true}}2.

    2022年8月18日
    7
  • mysql添加表注释、字段注释、查看与修改注释

    mysql添加表注释、字段注释、查看与修改注释

    2022年2月10日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号