이 글에서는 ThinkPHP3 함수의 M 메소드와 R 메소드를 자세히 소개합니다. M 메소드는 기본 모델 클래스를 인스턴스화하는 데 사용되며 R 메소드는 컨트롤러의 작동 메소드를 호출하는 데 사용됩니다. 관심 있는 친구는 스크립트를 따라갈 수 있습니다. 작은 모두에게 도움이 되길 바랍니다.
먼저 ThinkPHP 기능에 대한 자세한 설명을 소개하겠습니다. M 메소드
M 메소드는 기본 모델 클래스를 인스턴스화하는 데 사용됩니다. D 메소드와의 차이점은 다음과 같습니다.
1. IO 로딩 및 성능이 저하됩니다.
2. 인스턴스화 후에는 기본 모델 클래스(기본값은 Model 클래스)의 메서드만 호출할 수 있습니다.
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_');는 인스턴스화 모델 모델 클래스를 의미하며 db2 데이터베이스에서 think_user 테이블을 운영합니다.
두 번째 매개 변수가 비어 있거나 전달되지 않은 경우 현재 프로젝트 구성에서 데이터 테이블 접두사를 사용한다는 의미입니다. 운영 중인 데이터 테이블에 테이블 접두사가 없으면 다음을 사용할 수 있습니다.
$User = M('db1.User',null);는 모델 모델 클래스 및 운영 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方法的调用方式。
相关推荐:
위 내용은 TP3 기능의 M 방식과 R 방식에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!