Toggle navigation
菜菜小站
菜菜小站
前端开发
前端开发
前端基础
bootstrap
JavaScript
后端开发
后端开发
php开发
laravel
数据库
编辑器
git
服务器
服务器
https
cos云存储
ubuntu
homestead
微信开发
微信开发
微信小程序
python开发
python开发
python基础
关于
在laravel-admin的表单中使用ajax加载数据
作者:
菜菜子
|
时间:2018-03-24 10:39:00 |
分类:
前端开发
,
php开发
,
后端开发
,
JavaScript
,
laravel
|
访问: 2,864 次|
评论:
0 评论
一 、模拟一个场景,根据发货单来进行开票,在开票时需要根据开票数量,来计算开票总额,还需要获取未开票数量和未开票总额 二、 在admin目录下添加相关路由 ``` php // 根据发货单开发票 //根据发货单创建开票记录的表单 $router->get('delivery/{id}/invoice_create','DeliveryController@invoiceCreate')->name('delivery.invoice.create'); //表单的发送位置 $router->post('delivery_invoice', 'DeliveryController@invoiceStore')->name('delivery.invoice.store'); //表单ajax请求地址 $router->get('invoice_sync_data', 'DeliveryController@invoiceSyncData'); ``` 三、app/Admin下的bootstrap.php文件中加载js文件 ``` php Admin::js('/js/custom.js'); ``` 四、在/public/js文件夹中创建custom.js文件并写入需要调用的方法 ``` js function invoice_bind() { $("#num").on('change', function () { var num = $("input[name='num']").val(); var deliveryId = $("input[name='delivery_id']").val(); var max_num = $("input[name='delivery_num']").val(); if (num < 0) { alert("开票数量不能为负数"); num = 0; } else if (num > max_num) { alert("开票数量过大"); num = max_num; } $.get('/admin/invoice_sync_data', { 'num': num, 'deliveryId': deliveryId }, function (data) { console.log(data); $("input[name='num']").val(num); $('#invoice_price').val(data.invoice_price); $('#invoice_amount_price').val(data.invoice_amount_price); $('#invoice_no_num').val(data.invoice_no_num); $('#invoice_no_amount_price').val(data.invoice_no_amount_price); }); }); } ``` 五、 定义表单控制器 ``` php public function invoiceCreateForm($id) { //调用js方法 Admin::script('invoice_bind();'); return Admin::form(Delivery::class, function (Form $form) use ($id) { $form->setAction(route('delivery.invoice.store')); $form->row(function ($row) use ($id) { $delivery=Delivery::find($id); $row->hidden('_token', '_token')->default(csrf_token()); $row->hidden('delivery_id')->default($id)->attribute(['id'=>'delivery_id']); $row->width(4)->divide(); $row->width(4)->text('delivery_num', '发货数量')->attribute('disabled')->default($delivery->num); $row->width(12)->divide(); $row->width(4)->text('invoice_price', '发票价格')->attribute('disabled')->default($delivery->invoice_price); $row->width(4)->text('num', '开票数量')->rules('required'); $row->width(4)->text('invoice_amount_price', '发票总额')->attribute('disabled')->placeholder(' ');; $row->width(4)->divide(); $row->width(4)->text('invoice_no_num', '未开票数量')->attribute('disabled')->placeholder(' ');; $row->width(4)->text('invoice_no_amount_price', '未开票总额')->attribute('disabled')->placeholder(' ');; $row->width(12)->divide(); $row->width(4)->divide(); $row->width(4)->date('date', '开票日期')->rules('required'); $row->width(4)->text('no', '发票单号')->rules('required'); }); $form->ignore(['invoice_price','invoice_amount_price','invoice_no_amount_price','invoice_no_num']); }); } ``` 六、定义视图记载表单 ``` php public function invoiceCreate($id){ return Admin::content(function (Content $content) use ($id) { $content->header('开票'); $content->body($this->invoiceCreateForm($id)); }); } ``` 七、在控制器中写入ajax请求数据的方法 ``` php public function invoiceSyncData() { $num = request()->num; $deliveryId=request()->deliveryId; $delivery = Delivery::find($deliveryId); // dd($delivery->invoice_price); $invoice_price=$delivery->invoice_price;//发票价格 $invoice_amount_price=$invoice_price*$num; $invoice_no_num=$delivery->num-$num; $invoice_no_amount_price=$invoice_no_num*$invoice_price; return response()->json([ 'invoice_price' => $invoice_price, 'invoice_amount_price' => $invoice_amount_price, 'invoice_no_num' => $invoice_no_num, 'invoice_no_amount_price' => $invoice_no_amount_price, ]); } ``` 八、控制器写入表单存储方法 ``` php public function invoiceStore(Request $request) { $invoice=new Invoice; $invoice->delivery_id=$request->delivery_id; $invoice->date=$request->date; $invoice->no=$request->no; $invoice->num=$request->num; $invoice->save(); return redirect('/admin/invoice'); } ```
标签:
ajax
,
laravel5
还不快抢沙发
添加新评论
昵称(必填)
邮箱(必填)
网站(选填)
内容(必填)
提交评论
最新文章
ubuntu自动化安装php文件
laravel 操作redis
laravel-admin静态资源加速
laravel-admin1.6版本表单tag bug修复方法
laravel根据另外一列的值赋予grid某一列editable()
laravel-admin数据来源非数据表信息
laravel判定多对多关系是否存在
最新回复
森木志: 对的 用的就是这个版本 我看plugin.php的...
菜菜子: 插件版本呢?应该用https://github.com...
森木志: 忘记说了,typecho版本是1.2.1,php版本是...
森木志: 遇到灵异事件了,设置是没问题的,按道理来说上传成功后的...
局外人: 下载失败了,大佬帮忙看看是什么原因呢?
青丝: 7355763
菜菜子: 我好像沒有做這個提示,方便加微信吧,我看看什麼問題
青丝: 对的,提示需要8.0PHP
菜菜子: 你版本不對吧
菜菜子: 你是typecho1.2?用的是https://git...
标签
前端框架
bootstrap
laravel5
laravel-admin
laravel
微信小程序
gd库
git
wamp配置
https
表单
cos小工具
微信支付
ajax
cos
cos插件
vue
nginx
homestead
linux
ubuntu
swoole
typecho
编辑器
破解
数组
jwt
sql语言
腾讯云
邮件发送
websocket
队列
微信公众号
分页
日志
elasticsearch
wnmp
vagrant
无限极分类
分销
集合
supervisor
部署
grid
redis
python
标签
刷新
加密处理
验证码
悬浮框
权限控制
markdown
shell
mysql
测试
ui
任务调度
定时任务
deployer
gogs
反向代理
ftp
归档
2019年01月
2018年12月
2018年11月
2018年10月
2018年09月
2018年08月
2018年07月
2018年06月
2018年05月
2018年04月
2018年03月
2017年09月
2017年06月
2017年05月
2017年04月
2017年03月
2017年02月
2017年01月
2016年12月
2016年11月
友情链接
空
//