下载Laravel指定版本:
~~~
composer create-project laravel/laravel=8.6.5 --prefer-dist LaravelCMS
~~~
后台HTML模板:
https://adminlte.io
【Laravel迁移】
~~~
// 1.生成迁移
php artisan make:migration create_demos_table
// 2.设置表的字段设置
// 3.运行迁移
php artisan migrate
// 4.回滚迁移
php artisan migrate:rollback
// 5.重建数据库
php artisan migrate:refresh
~~~
【过长字段问题】
刚安装laravel运行php artisan的时候,会出现字段过长而无法正常运行,这时候需要在app\\Providers\\AppServiceProvider.php下加入以下代码:
~~~
use Illuminate\Support\Facades\Schema;
public function boot()
{
Schema::defaultStringLength(191);
}
~~~
【通过迁移文件,后加字段】
~~~
php artisan make:migration add_field_into_demos
~~~
~~~
// 运行迁移时会被调用
public function up()
{
Schema::table('users',function (Blueprint $table) {
$table->string('status')->after('content')->default(0);
});
}
// 回滚迁移时会被调用
public function down()
{
Schema::table('users', function (Blueprint $table) {
$table->dropColumn('status');
});
}
~~~
【模型】
~~~
// 1.最基础的模型
php artisan make:model Demo
// 2.指定表名和主键
protected $table = "remarks";
protected $primaryKey = 'remark_id';
// 3.加入常量的设置
const STATUS1 = 0;
const STATUS1 = 1;
~~~
新增功能,控制器部分:
~~~
/**
* create方法新增
*/
public function create(Request $request)
{
// 数据验证
$request->validate([
'title' => 'required|max:255',
'content' => 'required',
]);
// 保存数据
$data = [
'title' => request('title'),
'content' => request('content'),
];
Remark::create($data);
// 返回操作
return back();
}
/**
* save方法新增
*/
public function save(Request $request)
{
// 数据验证
$request->validate([
'title' => 'required|max:255',
'content' => 'required',
]);
// 保存数据
$model = new Remark();
$model->title = request('title');
$model->content = request('content');
$model->save();
// 返回操作
return back();
}
/**
* tinker方式新增
*/
public function tinker_demo()
{
$remark = new \App\Models\Remark;
$remark->title = 'title1';
$remark->content = 'content1';
$remark->save();
$remark = new \App\Models\Remark;
$remark->title = 'title2';
$remark->content = 'content2';
$remark->save();
$remark = new \App\Models\Remark;
$remark->title = 'title3';
$remark->content = 'content3';
$remark->save();
}
/**
* factory方式新增
*/
public function factory_demo()
{
// $user = User::factory()->create();
// $user = User::factory()->count(3)->create();
// php artisan make:factory RemarkFactory
$remark = Remark::factory()->count(3)->create();
return $remark;
}
~~~
编辑功能,html部分:
~~~
<a class="btn btn-info btn-sm remark-edit" id="id1" title="title1" content="content1" data-toggle="modal" data-target="#remark-edit">编辑</a>
<script>
$(document).ready(function()
{
$(".remark-edit").click(function()
{
var id = $(this).attr('id');
var title = $(this).attr('title');
var content = $(this).attr('content');
$("#edit_id").val(id);
$("#edit_title").val(title);
$("#edit_content").val(content);
});
});
</script>
~~~
更新功能,控制器部分:
~~~
/**
* update方法更新
*/
public function update(Request $request)
{
// 数据验证
$request->validate([
'edit_id' => 'required|integer',
'edit_title' => 'required|max:255',
'edit_content' => 'required',
]);
$remark = Remark::where('id', request('edit_id'))->first();
if(empty($remark)) {
return '找不到数据';
}
// 保存数据
$data = [
'title' => request('edit_title'),
'content' => request('edit_content'),
];
Remark::where('id', request('edit_id'))->update($data);
// 返回操作
return back();
}
/**
* save方法更新
*/
public function saveUpdate(Request $request)
{
// 数据验证
$request->validate([
'edit_id' => 'required|integer',
'edit_title' => 'required|max:255',
'edit_content' => 'required',
]);
$remark = Remark::where('id', request('edit_id'))->first();
if(empty($remark)) {
return '找不到数据';
}
// 保存数据
$remark->title = request('edit_title');
$remark->content = request('edit_content');
$remark->save();
// 返回操作
return back();
}
~~~
删除功能,jQuery部分:
~~~
function deleleRemark(id)
{
var ask = confirm('是否删除这个备注');
if(ask)
{
$.ajax({
type: "POST",
url: "/api/admin/remark/delete",
data: {
id: id,
key: 'key_value',
},
cache : false,
success: function(data)
{
window.location.reload();
} ,error: function(xhr, status, error)
{
alert(error);
},
});
}
}
~~~
新增字段:
~~~
php artisan make:migration add_delete_into_remarks
~~~
- 高级工程师或以上级别的行为习惯
- Laravel封装
- 公用类
- 查询
- 项目1
- Laravel CMS
- 无限分级列表
- Laravel
- Laravel简介
- Laravel下载和安装
- 微服务
- Laravel身份认证
- Laravel Passport
- 后台身份验证
- Passport实现前后端登录认证
- Laravel Sanctum
- Laravel辅助
- Unitest
- Laravel常用命令行
- Laravel数据库配置
- Laravel连接数据库模板
- Laravel数据库操作
- Laravel路由
- Laravel操作
- Laravel Blade模板引擎
- Laravel CRUD (create, read, update, delete)
- Laravel实例
- Laravel Eloquent
- belongsTo和belongsToMany案例
- Laravel Package
- Laravel File Manager
- Laravel language
- Laravel查询
- Laravel合并查询
- Laravel统计
- Laravel Voyager Blog System
- Laravel Excel
- Laravel AsgardCms后台
- Laravel基础集合
- Laravel 备份和更新
- Laravel和Codeigniter对比
- Laravel事务处理
- Laravel Redis
- Laravel在Nginx服务器运行时遇到404错误的修正
- Laravel安全
- Laravel JWT
- Laravel Passport
- Laravel加密和解密
- Laravel sent email
- laravel 5.4 eloquent-relationships
- 加入变量文件
- Laravel migrations
- Laravel队列
- Laravel+RabbitMQ
- Laravel OSS
- CMS设计
- 角色权限设计
- Lumen
- Lumen API
- lumen email
- 服务器
- Cloud9使用
- 配置本地服务器多域名
- PHP运行环境部署方式
- 同时运行PHP、Java、Python
- Linux操作
- Composer
- 支付开发
- 微信支付
- 支付宝API
- PayPal开发
- PHP基础
- JavaScript相對PHP開發側重後臺功能的劣勢
- PHP foreach 和 for循环
- PHP检测数组有哪里连续的字符串,以及有多少个
- Session
- 域名判断显示
- 检测登录设备
- PHP foreach循环, 则只循环相同数据一次
- PHP计算搜索过程所用的时间
- PHP文件处理
- Session和cookie案例:登录时的记住我功能
- PHP array判斷
- PHP剔除数组中相同子元素的值
- PHP分页
- PHP "三元运算符"简写
- 防CSRF跨站请求伪造攻击
- PHP Json system
- crul
- PHP爬虫
- 参考
- PHP一和二维数组
- 格式转换
- PHP抓取网页指定内容
- PHP Simple HTML DOM Parser
- PHP提取多维数组指定一列的方法大全
- PHP将第一个字符转为指定内容
- OpenSSL加密解密
- 图片+文字
- PHP理论
- Opcache
- Git
- 安装Git
- Git操作
- Git参考
- 参考笔记
- 程序员接单平台
- 后端PHP面试
- 基础面试
- MySQL训练题
- 经典算法题
- 框架原理
- 高并发
- 微服务架构
- 安全性
- 分布式设计
- 服务器集群
- 模拟题目
- 模拟面试1
- 模拟面试2
- 网络协议
- 英文面试
- 高端PHP面试取胜点
- MVC設計
- 模板引擎
- 算法高效解题
- 算法概述
- leetcode算法题
- 排序
- SQL
- MySQL
- MySQL连接
- Join案例
- MySQL参考文章
- mysql_pdo_select
- mysql_pdo_insert
- MySQL索引
- MySQL事务
- MySQL将数据表字段不重复的值合成一个数组
- MySQL常用语句
- 备份
- MySQL other
- MsSQL
- MsSQL连接
- MySQL PDO连接
- MsSQL安裝
- mssql_pdo_select
- mssql_pdo_insert
- MySQL past
- MySql常用操作
- MySQL基础练习
- MySQL设计
- MySQL案例
- php array转换放入数据表
- PHP Mysql连接数据库并输出数据
- MySQL常用命令
- MySQL导出导入
- PDO
- Excel
- Excel在Drupal的应用
- Excel在Laravel的应用
- PHPOffice/PhpSpreadsheet的基本使用
- 用PHP Simple HTML DOM Parser获取指定列的内容
- PHPOffice/PhpSpreadsheet的案例
- Sublime Text
- elasticsearch
- 后端基础核心:数据的输入和输出
- 发送邮件功能
- PHPMailer发送邮件功能源码
- PHPMailer发送邮件功能源码(详细案例)
- 常用cnd链接
- API
- API ajax+php demo
- PHP Postman API
- API1
- demo-api
- Google API
- google sheet data insert into database
- Laravel API
- Google Analytics
- 其他工具
- 经验
- 编程注意事项
- 开发语言的差别
- 软件产品
- 经验之谈
- test
- Bootstrap 4
- 1.demo page
- CMS設計
- 编辑器
- Other