Laravel入门笔记
Laravel 是一款简洁,优雅的一款框架,可以说是入门TP后的第二款可以选择的框架。
目录部分:
- app -> 自己写的代码
- http -> Controller -> 控制器
- bootstrap -> 框架自加载的文件
- config -> 配置文件
- database -> 关于数据库
- public -> 静态文件
- resources -> 视图
- storage -> 编译静态文件
- tests -> 用于测试代码
默认访问的文件是:public->index.php
路由:
存放路径:app/http/routes.php
TP 的访问模式是 用户访问->控制器->Model->视图
Laravel 的访问模式 用户访问->路由->控制器->Model->视图
简单的说,Laravel是通过路由来访问各个控制器的
类型:(常用的类型中的其中2种)
get: Route::get('basic1', function(){
return 'Hello World';
});
post: Route::post('basic2', function(){
return 'Hello World2';
});//不能用URL直接访问
多请求路由
match: Route::match(['get', 'post'], 'multy', function(){
return 'Hello World3';
});//既可以用get方式访问,也可以用post方式访问,即是指定方式请求。
any: Route::any('matrh', function(){
return 'Hello World4';
});//响应所有http请求。
路由参数
get:Route::get('user/{id}', function($id){
return 'User-id-'.$id;
});
默认值
Route::get('user/{name?}', function($name = 'sean'){
return 'User-name-'.$name;
});
用正则表达式判断
Route::get('user/{name?}', function($name){
return 'User-name-'.$name;
})->where('name', '[A-Za-z]+');//where('要匹配正则的字段', '正则的规则,用[]包含')
用正则判断多个字段
Route::get('user/{id}/{name}', function($id, $name){
return 'User-id-' . $id . ' User-name-' . $name;
})->where(['id' => '[0-9]+', 'name' => '[A-Za-z]+']);
路由别名
Route::get('user/member-user', ['as' => 'member', function(){
return 'member-user';
}]);
路由群组
Route::group(['prefix' => 'member', function(){
Route::get('user/{name}', function($name){
return 'user-'.$name;
});
Rount::get('user/{id}', function($id){
return 'id ='.$id;
})
}]);//访问的时候可以通过member前缀,访问路由群组里面的路由 例如:
/* 原本是http://localhost/Laravel/laravel52/public/user/name
加上前缀后变成http://localhost/Laravel/laravel52/public/menber/user/name
同样可以访问
*/
路由中输出视图
Route::get('view', function(){
return view('welcome');
});
总结:项目中的代码不能写在这里。路由只是用来接受请求,并转化给控制器中的方法进行处理。
控制器
路径:app/HttpControllers
新建一个控制器
1.和TP一样 MemberController.php
2.namespace App\Http\Controllers;
3.写个类
eg:class MemberController extends Controller
{
public function info()
{
return 'member-info';
}
}
路由和控制器关联
Route::get('member/info', 'MemberController@info');//Route::get('控制器名/控制器方法名', '控制器名Controller @ 控制器方法');
第二种方式:
Route::get('member/info', ['uses' => 'MemberController@info']);
控制器带参数
Route::any('member/{id}', ['uses' => 'MemberController@info']);
在控制器方法里面:
public function info($id)
{
return $id;
}
当要限制参数类型
Route::any('member/{id}', ['uses' => 'MemberController@info'])->where('id', '[0-9]+');
视图
路径:resources/views
输出视图
public function info()
{
return view('目录名/文件名');
}
前提是在视图层建好这个文件
命名规则: 文件名.blade.php;
一般一个控制器对应一个目录,如果控制器是MemberController.php 则建立一个member目录,控制器里要的视图存放在这个目录里面
以上总结:和TP一样
在控制器中带变量
public function inin()
{
return view('menber', [
'name'=>'陈77',
'age'=>'老不死'
]);
}
模版中输出变量
{{$name}} {{$age}}
模型
路径:app
新建一个模型:
namespace App;
use Illuminate\Database\Eloquent\Model;
class Member extends Model
{
public static function getMember()
{
return 'sean';
}
}
在控制器中使用
1.在开头位置
use App/模型名;
2.因为上面的模型是用静态方法定义
所以调用时候:模型名::模型里面的方法名();
操作数据库
三种方式
DB facade(原始查找)
查询构造器
Eloquent ORM
路径:
config/database.php
'prefix' => '表前缀'(没有可忽略)
对应.env文件
修改数据库配置
vendor/.env
DB_CONNECTION=mysql
DB_HOST=127.0.0.1 //服务器地址
DB_PORT=3306//端口号
DB_DATABASE=homestead//数据库名
DB_USERNAME=homestead//用户名
DB_PASSWORD=secret//密码
DB:原生语句查询
$res = DB::select('select * from goods'); dd($res);(相当于TP中的dump());
增加
$res = DB::insert('insert into goods(name, age) values(?, ?)',['sean', 18]);
更改
$res = DB::update('update goods set age = ? where name = ?', ['17', 'sean']);
删除
$res = DB::delete('delete from goods where id = ?', ['1001']);
查询构造器(重点)用内置的方法对数据库进行增删改查
简介:
提供方便,流畅的接口,用来建立以及执行数据库操作
使用PDO参数绑定,以保护应用程序免于SQL注入因此传入的是数据不需要另外转义特殊字符串
基本可以满足所有数据库操作。
要访问这个数据的方法,需要增加一条路由,输入访问的 URL 调用这个路由访问到控制器里面的方法。
增加
DB::table('goods')->insert([
['name' => 'name1', 'age' => 18],
['name' => 'name2', 'age' => 12]
]);
DB::table('goods')->insertGetId([
['name' => 'name1', 'age' => 18],
['name' => 'name2', 'age' => 12]
]);//获取到最后插入的ID
修改
DB::table('goods')->where('id', 2)->update(['age' => 13]);//把goods表的id=2的年龄改成age=13;
自增
DB::table('goods')->where('id', 2)->increment('age', 3);//把id=2的年龄自增3岁,不加数据默认自增一岁
自减
DB::table('goods')->where('id', 3)->decrement('age', 3)//把id=3的年龄自减3岁,不加数据默认自增一岁
自增/自减时候更改其他数据
DB::table('goods')->where('id', 2)->increment('age', 3, ['name', 'ii']);//自增的同时把name改成ii
删除
DB::table('goods')->where('id', '>=', 3)->delete();//删除id>=3的数据
DB::table('goods')->truncate();//清空数据库,谨慎使用
查询
get方法: $res = DB::table('goods')->get();//获取表的所有数据
dd($res);//Laravel的打印方式
first顺序方法: $res = DB::table('goods')->first();//顺序获取表的一条数据
first倒序方法: $res = DB::table('goods')->orderBy('id', 'desc')->first();//倒叙获取表的一条数据
where方法: $res = DB::table('goods')->where('id', '<=', 1001)->get();//按条件获取表的数据
where多个条件方法: $res = DB::table('goods')->where('id >= ? and age >= ?', ['1001', '18'])->get();//按多个条件获取表的数据
pluck返回某个字段:$name = DB::table('goods')->pluck('name');//只返回name这个字段的值
lists返回某个字段:$name = DB::table('goods')->lists('name', 'id');//只返回name这个字段的值,同时可以指定某个下标
select指定查询的字段:$name = DB::table('goods')->select('name', 'id')->get();//只查询name, id 字段的值
chunk限定每次返回几条:$name = DB::table('goods')->chunk(2, function($goods){
dd($goods);
return false;//加上这个条件,就只查询一次,
});//每次只查询两条,查完为止
Laravel入门笔记的更多相关文章
- Laravel 入门笔记
1.MVC简介 MVC全名是Model View Controller,是模型-视图-控制器的缩写 Model是应用程序中用于处理应用程序数据逻辑的部分 View是应用程序中处理数据显示的部分 Con ...
- laravel教程入门笔记
安装laravel框架 1.安装命令 composer create-project --prefer-dist laravel/laravel ytkah ytkah表示文件夹名,如果不写的话自动会 ...
- CI框架入门笔记
当前(2019-03-22)CodeIgniter 框架的最新版本是 3.1.5,于2017年6月发布,距今快两年了也没有更新,这与 Laravel 的更新速度相比差距太大了.因为确实,它是一个很古老 ...
- 每天成长一点---WEB前端学习入门笔记
WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...
- ES6入门笔记
ES6入门笔记 02 Let&Const.md 增加了块级作用域. 常量 避免了变量提升 03 变量的解构赋值.md var [a, b, c] = [1, 2, 3]; var [[a,d] ...
- [Java入门笔记] 面向对象编程基础(二):方法详解
什么是方法? 简介 在上一篇的blog中,我们知道了方法是类中的一个组成部分,是类或对象的行为特征的抽象. 无论是从语法和功能上来看,方法都有点类似与函数.但是,方法与传统的函数还是有着不同之处: 在 ...
- React.js入门笔记
# React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...
- redis入门笔记(2)
redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...
- redis入门笔记(1)
redis入门笔记(1) 1. Redis 简介 •Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure serv ...
随机推荐
- fancybox 关闭弹出窗口 parent.$.fancybox.close(); 无反应 fancybox 关闭弹出窗口父页面自动刷新,弹出子窗口前后事件
当我们在父页面使用 fancybox 弹出窗口后,如果想自己手动关闭,则可以 function Cancel() { parent.$.fancybox.close(); } 如果关闭没有反应,最好看 ...
- POJ 3259 Wormholes 虫洞(负权最短路,负环)
题意: 给一个混合图,求判断是否有负环的存在,若有,输出YES,否则NO.有重边. 思路: 这是spfa的功能范围.一个点入队列超过n次就是有负环了.因为是混合图,所以当你跑一次spfa时发现没有负环 ...
- VS2010下编译安装DarwinStreamingServer5.5.5
源码下载链接:http://dss.macosforge.org/源码版本: 5.5.5版本电脑环境:visual studio2010,window 7 x64系统.用VS2010打开WinNTSu ...
- Oracle中常见的33个等待事件小结
在Oracle 10g中的等待事件有872个,11g中等待事件1116个. 我们可以通过v$event_name 视图来查看等待事件的相关信息 一. 等待事件的相关知识 1.1 等待事件主要可 ...
- 【DFS】NYOJ-82 迷宫寻宝(一)-条件迷宫问题
[题目链接:NYOJ-82] #include<iostream> #include<cstring> using namespace std; struct node{ in ...
- Android中不混淆类中函数
情况一:混淆不同的函数aTest.bTest -keep class com.zony.Test { void aTest(byte[], int, int); void bTest(String, ...
- HTTP协议中的长连接和短连接(keep-alive状态)
什么是长连接 HTTP1.1规定了默认保持长连接(HTTP persistent connection ,也有翻译为持久连接),数据传输完成了保持TCP连接不断开(不发RST包.不四次握手),等待在同 ...
- 对LR analysis的平均事务响应时间和summary中时间值不同的解释
最近在做性能测试对LR结果分析时,又碰到了关于summary里与平均事务响应时间中各交易的响应时间值不同的问题.在此做个记录. 若交易中设置了思考时间,分析时需要注意查看是否过滤思考时间. 设置是否包 ...
- OpenGL超级宝典第5版&&glProvokingVertex
翻译:https://www.opengl.org/sdk/docs/man3/xhtml/glProvokingVertex.xml 方法原型:void glProvokingVertex(GLen ...
- qt 获取天气的接口
博客来源:http://blog.csdn.net/lzqwebsoft/article/details/7054045 网站api接口:http://smart.weather.com.cn/wzf ...