不会php能学laravel吗,在php中如何学习laravel框架(菜鸟初学者)

8a4e605ea51a6cb014203c9e6d239119.png

关于laravel的介绍就不讲了,总之laravel是款比较强大的框架,它是国外框架所以在安装的上面可能比较麻烦。

laravel的安装

首先安装laravel之前要安装composer,如果是linux系统即可直接下载安装,下载完后不能安装记得修改下文件权限用命令chmod,这边主要讲下window下如何使用composer这个工具。

首先百度搜索中国composer镜像,就可以找到composer config -g repositories.packagist composerhttp://packagist.phpcomposer.com这条命令,运行cmd在命令行运行上面的命令,就可以下载composer工具,

下载成功后可以看到composer文件底下有个composer.json文件这是一个配置文件,打开配置文件写明php版本信息和要下载的laravel信息,格式如下:{

"name": "laravel/laravel",

"description": "The Laravel Framework.",

"keywords": ["framework", "laravel"],

"license": "MIT",

"type": "project",

"require": {

"php": ">=5.5.9",

"laravel/framework": "5.1.*"

},

"require-dev": {

"fzaninotto/faker": "~1.4",

"mockery/mockery": "0.9.*",

"phpunit/phpunit": "~4.0",

"phpspec/phpspec": "~2.1"

},

"autoload": {

"classmap": [

"database"

],

"psr-4": {

"App\\": "app/"

}

},

"autoload-dev": {

"classmap": [

"tests/TestCase.php"

]

},

"scripts": {

"post-install-cmd": [

"php artisan clear-compiled",

"php artisan optimize"

],

"pre-update-cmd": [

"php artisan clear-compiled"

],

"post-update-cmd": [

"php artisan optimize"

],

"post-root-package-install": [

"php -r \"copy('.env.example', '.env');\""

],

"post-create-project-cmd": [

"php artisan key:generate"

]

},

"config": {

"preferred-install": "dist"

},

"repositories": [

{"type": "composer", "url": "http://packagist.phpcomposer.com"},

{"packagist": false}

]

}```

配置好之后输入composer install 进行安装laravel,这边要比较注意的是安装目录的路径问题,如果你想安装在d盘底下就在把命令行切到d目录底下进行安装(在此操作之前要配置好环境变量)。

laravel的目录结构介绍

安装完的第一次肯定是要想怎么去运行它,很简单,直接进入public文件就可以打开一个开始页面,如果在本地的话那就是localhost/laravelproject/public,就可以运行。

接下来介绍下laravel目录结构,首先介绍下public的index.php文件 里面主要是加载了开始文件然后才能成功运行laravel,具体的两个文件你可以在根目录下bootstrap文件夹中找到。现在看下app中的结构:

24ae5013db3889cf56d47b1a033259d0.png

view中主要放的是视图文件(创建文件时要用到blade模板,比如创建test.blade.php,laravel中是结合blade模板引擎来调用视图模板)

controller放的是控制器(手动创建时记得要用composer 命令进行更新)

config中主要是配置文件(比如配置数据库时要用到database.php文件)

models主要是放模型(也就是数据库的表)

routes则是路由配置,

filters则是过滤器。

laravel是怎么运行的

刚学习时肯定是要先尝试下如何运行这个laravel,首先手动创建一个controller,文件命名为TestController.php,然打开命令行进入项目的根目录下 执行 composer dumpautoload,里面内容可以模仿homeController.php。

然后编辑routes.php文件,将原来的Route::GET(‘/’,function()…);修改为Route::Get(‘/’,’TestController@showWelcome’); 然后运行也会跳到laravel欢迎界面。

如果Route::Get(‘test’,’TestController@showWelcome’);则在网站根目录下后面直接增加test就可以访问了,到了这里应该明白了怎么到Controller,Controller怎么到View了。

laravel数据库配置

这边用到的是mysql,进行了简单的配置'mysql' => array(

'driver' => 'mysql',

'host' => 'localhost',

'database' => 'oss',

'username' => 'root',

'password' => '',

'charset' => 'utf8',

'collation' => 'utf8_unicode_ci',

'prefix' => '',

)

laravel的数据库使用

数据表比较多时且数据表的前缀不一样,则可以先配置模型model,在models文件夹中建立一个文件要与表名一样的php文件,内容如下:<?php

use Illuminate\Auth\UserTrait;

use Illuminate\Auth\UserInterface;

use Illuminate\Auth\Reminders\RemindableTrait;

use Illuminate\Auth\Reminders\RemindableInterface;

class User extends Eloquent implements UserInterface, RemindableInterface {

use UserTrait, RemindableTrait;

/**

* The database table used by the model.

*

* @var string

*/

protected $table = 'users';

/**

* The attributes excluded from the model's JSON form.

*

* @var array

*/

protected $hidden = array('password', 'remember_token');

}

即可以直接使用 User ::all() 查询所有结果 ,User::find(2)查询一个,Post::findOrFail(2)

如果没找到就会返回错误,Post::save()、Post::where()->find()、Post::add()、Post::delete()

数据库的简便操作:DB::table(‘tablename’)->insert([

插入多个时要再加一个数组

['title'=>'title','name'=>'name']

['title'=>'title']

['title'=>'title']

])

插入时要想得到ID

DB::table('tablename')->insertGetId(['title'=>'titles'])

更新数据要有ID

DB::table('tablename')->where('id',1)->update(['title'=>'titles'])

删除数据

DB::table('tablename')->where('id',1)->delete();

查询数据

DB::table('tablename')->get(); 得到全部的值

DB::table('tablename')->get(['title']); 只查询title的值

DB::table('tablename')->first(); 只拿第一个

DB::table('tablename')->orderBy('id','desc')->first(); 根据id排序

DB::table('tablename')->where('id','!=',2)->get(); 不等于2

DB::table('tablename')->where('id','!=',2)->where('id','>',5)->get(); 可以使用多个where

DB::table('tablename')->where('id','!=',2)->OrWhere('id','>',5)->get(); 或者

DB::table('tablename')->whereBetween('id',[2,5])->get(); 闭包之间

DB::table('tablename')->whereIn('id',[2,5,9])->get();

DB::table('tablename')->whereNotIn('id',[2,5,9])->get();

DB::table('tablename')->whereNull('id')->get(); 为空的话就可以查询出来

DB::table('tablename')->take(3)->get(); 只查询3个

DB::table('tablename')->limit(3)->get(); 只查询3个

DB::table('tablename')->skip(2)->take(3)->get(); 只查询3个跳过第二个

DB::table('tablename')->where('id','!=',2)->pluck('title'); 只返回它的title

DB::table('tablename')->count(); 有多少条记录

DB::table('tablename')->max('id');

DB::table('tablename')->min('id');

DB::table('tablename')->avg('id');

DB::table('tablename')->sum('id');

多表关联

在Post中定义public function comment(){ return $this->hasMany('Comment','post_id') }

正向关联 一对多 一对一是hasOne

在Comment中定义public function post(){ return $this->belongsTo('Post','post_id') }

反向关联

取得关联值Post::find(2)->comment 就可以得到Comment这张表的内容 //这样查询一个是可以的 查询多个就要设置预载入

查询多个

Post::with('comment')->get();

Post::with(['comment'=>function($query){$query->where('id','>',2)}])->get(); 加条件

感谢大家的阅读,希望大家有所收益。

本文转自:https://blog.csdn.net/Happy_CSDN/article/details/49363219

推荐教程:《php教程》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值