laravel基础课程---12、lavarel的ajax操作2(lavarel的ajax使用总结)
laravel基础课程---12、lavarel的ajax操作2(lavarel的ajax使用总结)
一、总结
一句话总结:
比较简单:就是js请求ajax,然后控制器获取请求参数,返回数据即可
1、laravel修改某个板块修改图片中 form的目标地址action如何写?
路径带参数+路由参数:form action="/admin/pic/{{$data->id}}":这样传过来的路由参数(比如id)在控制器中用一个变量接收就好
2、lavarel查看页面提交的所有数据?
Request对象的all()方法
3、比如修改某个板块操作需要做成无刷修改么?
不需要,直接跳回列表页面即可
4、修改板块(板块中带图片)操作需要注意的是什么?
删除原图操作:原图和新图是否一样,不一样就删除原图
5、无刷新分页的实现思路及原理?
数据库实现原理:分页的原理 limit
思路一:vue双向绑定+ajax(推荐):
思路二:控制器直接返回分页页面数据
1、分页的原理 limit
1 0,3
2 3,3
3 6,3
6、最基本 的分页实现思路?
控制器:确定分页和页数和每页显示的数据
视图:ajax请求分页 + 遍历输出分页图标
控制器返回的数据:分页视图要显示的数据 :和我项目中的一样
<!-- 分页效果 -->
<div class="panel-footer">
<nav style="text-align:center;">
<ul class="pagination">
@for($i=1;$i<=$page;$i++) <li><a href="javascript:;" onclick="page1(this,{{$i}})">{{$i}}</a></li>
@endfor
</ul>
</nav> </div>
// 无刷新的分页
function page(obj,page){
// 发送ajax请求
var str='<tr><th><input type="checkbox" name="" id=""></th><th>ID</th><th>TITLE</th><th>SORT</th><th>IMG</th><th>操作</th></tr>';
$.get('/admin/pic',{'page':page},function(data){
// 处理数据
for(var i=0;i<data.length;i++){
str+='<tr id="tr'+data[i].id+'">';
str+='<td><input type="checkbox" value="'+data[i].id+'" name="" class="inputs" id=""></td>';
str+='<td>'+data[i].id+'</td>'
str+='<td>'+data[i].title+'</td>'
str+='<td><input type="text" onchange="change(this,'+data[i].id+'" value="'+data[i].sort+'" name="" id=""></td>'
str+='<td><img width="200px" src="/Uploads/Goods/'+data[i].img+'" alt=""></td>'
str+='<td><a href="/admin/pic/'+data[i].id+'/edit" class="glyphicon glyphicon-pencil"></a> <a href="javascript:;" onclick="del(this,'+data[i].id+')" class="glyphicon glyphicon-trash"></a></td>';
str+='</tr>';
}
// 写入到表格中
$("#table").html(str);
});
}
控制器
// 后台商品管理首页方法
public function index(){
// 计算数据的总条数
$tot=\DB::table("pic")->count();
// 每页展示几条数据
$length=3;
// 计算总页数
$page=ceil($tot/$length);
// 判断地址栏参数是否存在
if (isset($_GET['page'])) {
// 计算分页
$offset=($_GET['page']-1)*$length;
// 进行数据库查询
$data=\DB::select("select * from pic order by sort asc limit $offset,$length");
// 返回JSON
// return $data;
// 返回页面
return view('admin.pic.page')->with('data',$data);
}
// 从数据库中读取相关数据
$data=\DB::select("select * from pic order by sort asc limit 0,$length");
// dd($data);
// 加载用户管理页面
return view('admin.pic.index')->with('data',$data)->with('page',$page);
}
7、做无刷新分页的时候,如果不用vue双向绑定,直接用php来实现,那么更新分页数据会需要非常麻烦复杂的在js中的拼接 html代码,如何解决?
新弄了一个page页面:直接在控制器中返回这个页面:这样不用拼接复杂的html代码
直接在控制器中返回一个page页面:在页面中 刷新page数据(是一个page页面):return view('admin.pic.index')->with('data',$data)->with('page',$page);
控制器
// 后台商品管理首页方法
public function index(){
// 计算数据的总条数
$tot=\DB::table("pic")->count();
// 每页展示几条数据
$length=3;
// 计算总页数
$page=ceil($tot/$length);
// 判断地址栏参数是否存在
if (isset($_GET['page'])) {
// 计算分页
$offset=($_GET['page']-1)*$length;
// 进行数据库查询
$data=\DB::select("select * from pic order by sort asc limit $offset,$length");
// 返回JSON
// return $data;
// 返回页面
return view('admin.pic.page')->with('data',$data);
}
// 从数据库中读取相关数据
$data=\DB::select("select * from pic order by sort asc limit 0,$length");
// dd($data);
// 加载用户管理页面
return view('admin.pic.index')->with('data',$data)->with('page',$page);
}
function page1(obj,page){
// 发送ajax请求
$.get('/admin/pic',{'page':page},function(data1){
// 处理数据
alert($("#main").html());
$("#main").html(data1);
});
}
page.blade.php <th><input type="checkbox" name="" id=""></th>
<th>ID</th>
<th>TITLE</th>
<th>SORT</th>
<th>IMG</th>
<th>操作</th> @foreach($data as $value)
<tr id="tr{{$value->id}}">
<td><input type="checkbox" value="{{$value->id}}" name="" class="inputs" id=""></td>
<td>{{$value->id}}</td>
<td>{{$value->title}}</td>
<td><input type="text" onchange="change(this,{{$value->id}})" value="{{$value->sort}}" name="" id=""></td>
<td><img width="200px" src="/Uploads/Goods/{{$value->img}}" alt=""></td>
<td><a href="/admin/pic/{{$value->id}}/edit" class="glyphicon glyphicon-pencil"></a> <a href="javascript:;" onclick="del(this,{{$value->id}})" class="glyphicon glyphicon-trash"></a></td>
</tr> @endforeach
二、内容在总结中
laravel基础课程---12、lavarel的ajax操作2(lavarel的ajax使用总结)的更多相关文章
- laravel基础课程---13、数据库基本操作2(lavarel数据库操作和tp对比)
laravel基础课程---13.数据库基本操作2(lavarel数据库操作和tp对比) 一.总结 一句话总结: 非常非常接近:也是分为两大类,原生SQL 和 数据库链式操作 学习方法:使用时 多看手 ...
- laravel基础课程---14、表单验证(lavarel如何进行表单验证)
laravel基础课程---14.表单验证(lavarel如何进行表单验证) 一.总结 一句话总结: lavarel的验证的功能比tp要[简单]且[强大]很多 直接控制器中:添加[规则数组]和[修改提 ...
- laravel基础课程---15、分页及验证码(lavarel分页效果如何实现)
laravel基础课程---15.分页及验证码(lavarel分页效果如何实现) 一.总结 一句话总结: 数据库的paginate方法:$data=\DB::table("user" ...
- laravel基础课程---11、lavarel的ajax操作(ajax优劣势是什么)
laravel基础课程---11.lavarel的ajax操作(ajax优劣势是什么) 一.总结 一句话总结: 优势:用户友好度:异步通信,不会频繁刷新页面,用户友好度比较高 优势:减轻数据库压力 缺 ...
- laravel基础课程---9、视图(lavarel的模板语法和tp相比怎样)
laravel基础课程---9.视图(lavarel的模板语法和tp相比怎样) 一.总结 一句话总结: lavarel的模板语法比thinkphp好用很多:和html代码配合的更好 lavarel比t ...
- laravel基础课程---10、数据库基本操作(如何使用数据库)
laravel基础课程---10.数据库基本操作(如何使用数据库) 一.总结 一句话总结: 1.链接数据库:.env环境配置里面 2.执行数据库操作:DB::table('users')->up ...
- laravel基础课程---8、laravel响应和视图(响应是什么)
laravel基础课程---8.laravel响应和视图(响应是什么) 一.总结 一句话总结: 就是向请求返回的响应数据(一般为html(视图),当然也可以是变量值):所有的路由及控制器必须返回某个类 ...
- laravel基础课程---16、数据迁移(数据库迁移是什么)
laravel基础课程---16.数据迁移(数据库迁移是什么) 一.总结 一句话总结: 是什么:数据库迁移就像是[数据库的版本控制],可以让你的团队轻松修改并共享应用程序的数据库结构. 使用场景:解决 ...
- laravel基础课程---7、文件处理、闪存、cookie(cookie原理和使用场景)
laravel基础课程---7.文件处理.闪存.cookie(cookie原理和使用场景) 一.总结 一句话总结: 页面请求服务器的时候是把这个页面中所有的cookie都带上了的,cookie里面也存 ...
随机推荐
- DFRobot万物互联大赛第二轮
前言 最近放在阳台的花草被啥东西给吃了,然后厨房挂在墙上的小虾米也不知道咋的被抓破吃光了(我怀疑是隔隔壁两条泰迪),所以打算做个简单的项目,教训一下偷吃贼.时间比较仓促,内容比较多,能力有比较有限,好 ...
- html5,audio音乐播放器
最终,做了自己原来一直想要实现的事儿.得出的结果是,有些事儿一旦開始做了,那么它就并非非常难. 如今的我,正听着自己的播放器放出的<光辉岁月>写这篇周六清晨的博文.写的不是非常好.但也请各 ...
- (八)jQuery中的事件
1.加载DOM在常规的JavaScript中,使用window.onload方法:而在jQuery中,使用$(document).ready(function(){ })方法.window.onloa ...
- ASP.NET MVC 扩展自定义视图引擎支持多模板&动态换肤skins机制
ASP.NET mvc的razor视图引擎是一个非常好的.NET MVC 框架内置的视图引擎.一般情况我们使用.NET MVC框架为我们提供的这个Razor视图引擎就足够了.但是有时我们想在我们的 ...
- 浅谈java反序列化工具ysoserial
前言 关于java反序列化漏洞的原理分析,基本都是在分析使用Apache Commons Collections这个库,造成的反序列化问题.然而,在下载老外的ysoserial工具并仔细看看后,我发现 ...
- linux SPI驱动——spi core(四)
一: SPI核心,就是指/drivers/spi/目录下spi.c文件中提供给其他文件的函数,首先看下spi核心的初始化函数spi_init(void). 1: static int __init s ...
- 【虚拟机】WIN8.1系统虚拟机完全彻底删除
一.首先删除注册表 用管理员身份打开CMD,输入F:\>VMware-workstation-full-12.5.5-5234757.exe/clean,根据自己的虚拟机安装文件的路径进行改变( ...
- CocoaPods Podfile详解与使用
1.为什么需要CocoaPods 在进行iOS开发的时候,总免不了使用第三方的开源库,比如SBJson.AFNetworking.Reachability等等.使用这些库的时候通常需要: 下载开源库的 ...
- andeoid硬件解码
Finally, I must say, finally, we get low-level media APIs in Android, the Android hardware decoding ...
- OpenCV 入门示例之三:AVI 视频播放控制
前言 在前文中给出了一个非常简短的视频播放程序,但它没有实现常规视频播放器中的播放滚动条功能,本文对此视频播放器程序加以改进,实现此功能. 滚动条的实现思路 滚动条的功能实质上就是从一帧跳跃到另外一帧 ...