이 기사는 laravel에 대한 관련 지식을 제공합니다. Laravel 설치 방법, 라우팅, 유효성 검사기 및 기타 관련 내용을 포함한 몇 가지 기본 지식을 함께 살펴보겠습니다. 모두가 도움이 됩니다.
[관련 권장 사항: laravel 비디오 튜토리얼]
composer create- 프로젝트 라브 el /laravel 프로젝트 폴더 이름--prefer-dist
composer create-project laravel/laravel 项目文件夹名 --prefer-dist
app
:应用程序的核心代码
bootstrap
:一个引导框架的app.php文件,一个cache目录(包含路由及缓存文件),框架启动文件,一般情况不动。
config
:所有配置文件
database
:其中migrations目录可以生成数据表。
public
:入口文件存放地,以及静态资源(和tp类似)
resources
:
routes
:应用的所有路由定义
tests
:可用来单元测试
vendor
app
: 애플리케이션의 핵심 코드🎜bootstrap
: 프레임워크, 캐시 디렉터리(라우팅 및 캐시 파일 포함), 프레임워크 시작 파일을 안내하는 app.php 파일입니다. 일반적으로 이동하지 않습니다. 🎜config
: 모든 구성 파일 🎜database
: migrations 디렉터리는 데이터 테이블을 생성할 수 있습니다. 🎜공개
: 항목 파일 저장 위치 및 정적 리소스(tp와 유사) 🎜리소스
: 🎜 routes
: 애플리케이션의 모든 경로 정의🎜tests
: 단위 테스트에 사용할 수 있습니다🎜 li>🎜vendor
: 모든 작곡가 종속성 패키지🎜Route::match(['get','post'],'/',function(){});
Route::any('/home', function () { });
/admin/add
Route::get('/home/{id}', function ($id) { echo 'id为:'.$id;});
命令行创建路由:
php artisan make:controller Admin/IndexController
基本路由建立:
Route::get('test/index','TestController@index');
分目录路由建立:
Route::get('/admin/index/index','Admin\IndexController@index');
引入:use Illuminate\Support\Facades\Validator
$param = $request->all();$rule = [ 'name'=>'required|max:2',];$message = [ 'required' => ':attribute不能为空', 'max' => ':attribute长度最大为2'];$replace = [ 'name' => '姓名',];$validator = Validator::make($param, $rule, $message,$replace);if ($validator->fails()){ return response()->json(['status'=>0,'msg'=>$validator->errors()->first()]);}
在控制器中如果要使用一个类,例如use Illuminate\Http\Request
,就可以简写为use Request
。
但是需要在config目录下的app.php配置文件中加入:
'aliases' => [ 'App' => Illuminate\Support\Facades\App::class, 'Arr' => Illuminate\Support\Arr::class, 'Artisan' => Illuminate\Support\Facades\Artisan::class, 'Auth' => Illuminate\Support\Facades\Auth::class, 'Blade' => Illuminate\Support\Facades\Blade::class, 'Request' => Illuminate\Support\Facades\Request::class, ],
Input::get('id')
Input::all()
打印出来的是数组
关于dd(dump+die)
Input::only(['id','name'] //只接收id,其余不接受
Input::except(['name'] //不接收name,其余都接收
Input::has('name') //存在返回true 不存在返回false 其中0返回true
视图也可分目录管理:
控制器语法:
return view('home/test');
也可写为:
return view('home.test');
控制器中:
return view('home/test',['day'=>time()]);
视图中:
{{$day}}
其中控制器中变量映射有三种:
了解一下compact数组。
控制器中:
public function index(){ $arr = [ 0 => [ 'name' => 'tom', 'age' => '12', ], 1 => [ 'name' => 'bby', 'age' => '13', ] ]; return view('home/test',['data'=>$arr]); }
视图中:
@foreach($data as $k=>$v) 键:{{$k}} 值:{{$v['name']}} <br>@endforeach
@if(1==2) 是的 @else 不是的 @endif
@include('welcome')
php artisan make:model Model/Admin/Member
此时,就会在app目录内创建:
<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Member extends Model{ //定义表名 protected $table = 'student'; //定义主键 protected $primaryKey = 'id'; //定义禁止操作时间 public $timestamps = false; //设置允许写入的字段 protected $fillable = ['id','sname'];}
方式一:
$model = new Member(); $model->sname = '勒布朗'; $res = $model->save(); dd($res);
方式二:
$model = new Member(); $res = $model->create($request->all()); dd($res);
//查询客户与销售顾问的客资列表$data = Custinfo::select(['custinfo.*', 'customers.name']) ->join('customers', 'customers.id', '=', 'custinfo.cust_id') ->where($where) ->get() ->toArray();
<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Phone extends Model{ //定义表名 protected $table = 'phone'; //定义主键 protected $primaryKey = 'id'; //定义禁止操作时间 public $timestamps = false; //设置允许写入的字段 protected $fillable = ['id','uid','phone'];}
<?phpnamespace App\Model\Admin;use Illuminate\Database\Eloquent\Model;class Member extends Model{ //定义表名 protected $table = 'student'; //定义主键 protected $primaryKey = 'id'; //定义禁止操作时间 public $timestamps = false; //设置允许写入的字段 protected $fillable = ['id','sname']; /** * 获取与用户关联的电话号码记录。 */ public function getPhone() { return $this->hasOne('App\Model\Admin\Phone', 'uid', 'id'); }}
//对象转数组 public function Arr($obj) { return json_decode(json_encode($obj), true); } public function index(){ $infoObj = Member::with('getPhone')->get(); $infoArr = $this->Arr($infoObj); print_r($infoArr); }
在config
目录下的logging.php
中的channels
配置:
'custom' => [ 'driver' => 'single', 'path' => storage_path('logs/1laravel.log'), 'level' => 'debug', ]
控制器中:
$message = ['joytom','rocker'];Log::channel('custom')->info($message);
建立一个迁移文件:php artisan make:migration create_shcool_table
会在database\migrations
下创建一个文件:
在up方法中增加如下代码:
<?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illuminate\Support\Facades\Schema;class CreateShcoolTable extends Migration{ /** * Run the migrations. * * @return void */ public function up() { Schema::create('shcool', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('school_name','20')->notNull()->unique(); $table->tinyInteger('status')->default(1); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('shcool'); }}
更详细的生成SQL方法请参考:数据迁移文件常用方法速查表
写好SQL文件以后,执行:php artisan migrate
将会生成数据表,其中操作日志将记录在这个表中:
php artisan migrate:rollback
:回滚最后一次的迁移操作, 删除(回滚)之后会删除迁移记录,并且数据表也会删除,但是迁移文件依旧存在,方便后期继续迁移(创建数据表)。
【相关推荐:laravel视频教程】
위 내용은 Laravel의 기본 지식을 요약하고 정리합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!