이 글은 ThinkPHP 기능의 자세한 설명에 대해 주로 M 메소드와 R 메소드를 소개합니다. 이제 필요한 친구들이 참고할 수 있도록 공유하겠습니다.
먼저 소개하겠습니다. ThinkPHP 기능에 대한 자세한 설명: M 메서드
M 메서드는 기본 모델 클래스를 인스턴스화하는 데 사용됩니다. D 메서드와의 차이점은 다음과 같습니다.
1 모델 클래스를 사용자 정의할 필요가 없으며 IO 로딩이 줄어듭니다.
2. 기본 모델 클래스의 메서드만 호출할 수 있습니다.
3 인스턴스화할 때 테이블 접두사, 데이터베이스 및 데이터베이스 연결 정보를 지정할 수 있습니다.
D 메서드의 힘은 캡슐화하는 사용자 정의 모델에 반영됩니다. 클래스가 아무리 강력하더라도 ThinkPHP 프레임워크 새 버전의 기본 모델 클래스가 점점 더 강력해짐에 따라 M 메서드도 점점 더 강력해지고 있습니다. D 방법보다 더 실용적입니다.
M 메소드의 호출 형식:
M('[기본 모델 이름:]모델 이름','데이터 테이블 접두사','데이터베이스 연결 정보')
M 메소드의 구체적인 용도를 살펴보겠습니다. M 방법:
1. 기본 모델(Model) 클래스 인스턴스화
모델이 정의되지 않은 경우 다음 방법을 사용하여 작업을 위한 모델 클래스를 인스턴스화할 수 있습니다.
//实例化User模型 $User = M('User'); //执行其他的数据操作 $User->select();
이 방법은 모델 클래스를 정의할 필요가 없으므로 프로젝트 간 호출을 지원하므로 효율적입니다. 단점은 커스텀 모델 클래스가 없어 관련 비즈니스 로직을 작성할 수 없고 기본적인 CURD 작업만 완료할 수 있다는 점이다.
$User = M('User');
은 실제로 다음과 동일합니다.
$User = new Model('User');
은 think_user 테이블을 운영한다는 의미입니다. M 메서드에도 D 메서드와 마찬가지로 싱글톤 함수가 있으며, 여러 번 호출해도 반복적으로 인스턴스화되지 않습니다. M 메소드의 모델 이름 매개변수는 데이터 테이블로 변환될 때 자동으로 소문자로 변환됩니다. 이는 ThinkPHP의 데이터 테이블 이름 지정 사양이 모두 소문자 형식임을 의미합니다.
2. 다른 공개 모델 클래스 인스턴스화
첫 번째 인스턴스화 방법은 모델 클래스에 대한 정의가 없기 때문에 일부 추가적인 논리적 메서드를 캡슐화하기 어렵지만 대부분의 경우 그냥 수행하면 됩니다. 몇 가지 일반적인 논리를 확장한 후 다음 방법을 시도해 볼 수 있습니다.
$User = M('CommonModel:User');
변경된 사용법은 실제로 다음과 같습니다.
$User = new CommonModel('User');
시스템의 모델 클래스가 자동으로 로드될 수 있으므로 인스턴스화하기 전에 클래스 라이브러리를 수동으로 가져올 필요가 없습니다. 모델 클래스 CommonModel은 Model을 상속해야 합니다. CommonModel 클래스에서 몇 가지 일반적인 논리적 메서드를 정의할 수 있으므로 각 데이터 테이블에 대해 특정 모델 클래스를 정의할 필요가 없습니다. 프로젝트에 이미 100개 이상의 데이터 테이블이 있는 경우 대부분은 기본입니다. CURD 작업의 경우 일부 모델에만 있습니다. 캡슐화해야 하는 복잡한 비즈니스 논리이므로 첫 번째 방법과 두 번째 방법을 조합하는 것이 좋습니다.
3. 테이블 접두사, 데이터베이스 및 기타 정보 전달
M 메서드에는 세 가지 매개 변수가 있습니다. 첫 번째 매개 변수는 모델 이름(기본 모델 클래스 및 데이터베이스를 포함할 수 있음)이고 두 번째 매개 변수는 데이터 테이블 접두사(현재 프로젝트 구성의 테이블 접두사를 가져오려면 비워 두세요), 세 번째 매개변수는 현재 사용되는 데이터베이스 연결 정보를 설정하는 데 사용됩니다(현재 프로젝트 구성의 데이터베이스 연결 정보를 가져오려면 비워 두세요). 예:
$User = M('db2.User','think_');
Model 모델 클래스를 인스턴스화하고 db2 데이터베이스에서 think_user 테이블을 운영함을 나타냅니다.
두 번째 매개 변수가 비어 있거나 전달되지 않은 경우 현재 프로젝트 구성에서 데이터 테이블 접두사를 사용한다는 의미입니다. 운영 중인 데이터 테이블에 테이블 접두사가 없으면
$User = M('db1.User',null);
을 사용할 수 있습니다. Model 모델 클래스를 인스턴스화하고 db1 데이터베이스에서 사용자 테이블을 운영하는 것을 의미합니다.
운영하는 데이터베이스에 다른 사용자 계정이 필요한 경우 데이터베이스 연결 정보를 전달할 수 있습니다. 예:
$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');
은 기본 모델 클래스가 Model을 사용한 다음 think_user 테이블을 작동하고 user_a를 사용한다는 의미입니다. 데이터베이스에 연결하기 위한 계정, 운영 데이터베이스는 thinkphp입니다.
세 번째 연결 정보 매개변수는 DSN 구성 또는 어레이 구성을 사용할 수 있으며 구성 매개변수도 지원할 수 있습니다.
예를 들어 프로젝트 구성 파일
'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';
에 구성된 경우 다음을 사용할 수 있습니다.
$User = M('User','think_','DB_CONFIG');
기본 모델 클래스와 데이터베이스를 함께 사용할 수 있습니다. 예:
$User = M('CommonModel:db2.User','think_');
공용 모델 클래스를 사용하여 계층적 모델을 인스턴스화하려는 경우 다음을 사용하여
M('UserLogic:User');
를 사용하여 UserLogic을 인스턴스화할 수 있습니다. 비록 이는 의미가 없지만
를 사용하여 동일한 작업을 수행할 수 있기 때문입니다.
D('User','Logic');
기능.
ThinkPHP 기능에 대한 자세한 설명: R 메소드
R 메소드는 특정 컨트롤러의 작동 메소드를 호출하는 데 사용되며 이는 A 메소드를 더욱 향상시키고 보완한 것입니다. 방법 A의 사용법은 여기를 참조하세요.
R 메서드 호출 형식:
R('[Project://][Group/]Module/Operation','Parameters','Controller layer name')
예를 들어 작업 메서드를 다음과 같이 정의합니다.
class UserAction extends Action { public function detail($id){ return M('User')->find($id); } }
那么就可以通过R方法在其他控制器里面调用这个操作方法(一般R方法用于跨模块调用)
$data = R('User/detail',array('5'));
表示调用User控制器的detail方法(detail方法必须是public类型),返回值就是查询id为5的一个用户数据。如果你要调用的操作方法是没有任何参数的话,第二个参数则可以留空,直接使用:
$data = R('User/detail');
也可以支持跨分组和项目调用,例如:
R('Admin/User/detail',array('5'));
表示调用Admin分组下面的User控制器的detail方法。
R('Admin://User/detail',array('5'));
表示调用Admin项目下面的User控制器的detail方法。
官方的建议是不要在同一层多太多调用,会引起逻辑的混乱,被公共调用的部分应该封装成单独的接口,可以借助3.1的新特性多层控制器,单独添加一个控制器层用于接口调用,例如,我们增加一个Api控制器层,
class UserApi extends Action { public function detail($id){ return M('User')->find($id); } }
然后,使用R方法调用
$data = R('User/detail',array('5'),'Api');
也就是说,R方法的第三个参数支持指定调用的控制器层。
同时,R方法调用操作方法的时候可以支持操作后缀设置C('ACTION_SUFFIX'),如果你设置了操作方法后缀,仍然不需要更改R方法的调用方式。
以上内容给大家分享了ThinkPHP函数详解之M方法和R方法,希望对大家有所帮助。
相关推荐:
위 내용은 ThinkPHP 기능에 대한 자세한 설명: M 메소드와 R 메소드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!