laravel结合vue添加权限的实现示例

admin3年前PHP教程42
目录
一、添加(权限)节点1.1、引入vue1.2、添加模版(vue、jquery)1.3、添加节点控制器逻辑1.4、模型中定义修改器1.5、效果:

 

一、添加(权限)节点

 

1.1、引入vue

使用vue进行界面管理,实现添加功能
我们在这个目录下存入vue.js:

 

1.2、添加模版(vue、jquery)

resources/admin/node/create.blade.php:

<!--_meta 作为公共模版分离出去--><!DOCTYPE HTML><html><head><meta charset="utf-8"><meta name="renderer" content="webkit|ie-comp|ie-stand"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" /><meta http-equiv="Cache-Control" content="no-siteapp" /><link rel="Bookmark" href="/favicon.ico"><link rel="Shortcut Icon" href="/favicon.ico" /><link rel="stylesheet" type="text/css" href="/admin/static/h-ui/css/H-ui.min.css" /><link rel="stylesheet" type="text/css" href="/admin/static/h-ui.admin/css/H-ui.admin.css" /><link rel="stylesheet" type="text/css" href="/admin/lib/Hui-iconfont/1.0.8/iconfont.css" /><link rel="stylesheet" type="text/css" href="/admin/static/h-ui.admin/skin/default/skin.css" id="skin" /><link rel="stylesheet" type="text/css" href="/admin/static/h-ui.admin/css/style.css" /><title>添加节点</title></head><body><nav class="breadcrumb"><i class="Hui-iconfont">&#xe67f;</i> 首页 <span class="c-gray en">&gt;</span> 用户中心 <span class="c-gray en">&gt;</span> 添加节点 <a class="btn btn-success radius r" style="line-height:1.6em;margin-top:3px" href="javascript:location.replace(location.href);" placeholder="路由别名" name="route_name"></div></div><div class="row cl"><label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>是否菜单:</label><div class="formControls col-xs-8 col-sm-9 skin-minimal"><div class="radio-box"><input type="radio" v-model="info.is_menu" value="1"><label for="sex-1">是</label></div><div class="radio-box"><input type="radio" v-model="info.is_menu" value="0"><label for="sex-2">否</label></div></div></div><div class="row cl"><div class="col-xs-8 col-sm-9 col-xs-offset-4 col-sm-offset-3"><input class="btn btn-primary radius" type="submit" value="添加节点"></div></div></form></article><!--_footer 作为公共模版分离出去--><script type="text/javascript" src="/admin/lib/jquery/1.9.1/jquery.min.js"></script><script type="text/javascript" src="/admin/lib/layer/2.4/layer.js"></script><script type="text/javascript" src="/admin/static/h-ui/js/H-ui.min.js"></script><script type="text/javascript" src="/admin/static/h-ui.admin/js/H-ui.admin.js"></script><!--/_footer 作为公共模版分离出去--><!--请在下方写此页面业务相关的脚本--><script type="text/javascript" src="/admin/lib/My97DatePicker/4.8/WdatePicker.js"></script><script type="text/javascript" src="/admin/lib/jquery.validation/1.14.0/jquery.validate.js"></script><script type="text/javascript" src="/admin/lib/jquery.validation/1.14.0/validate-methods.js"></script><script type="text/javascript" src="/admin/lib/jquery.validation/1.14.0/messages_zh.js"></script><!-- vue --><script src="/js/vue.js"></script><script type="text/javascript">new Vue({el: ".page-container",data: {info: {_token: "{{csrf_token()}}",pid: 0,name: "",route_name: "",is_menu: 0,}},methods: {// dopost (e) {// let url = e.target.action// $.post(url, this.info).then((res) => {// console.log(res);// })// }async dopost (e) {let url = e.target.actionlet res = await $.post(url, this.info)if (res.status == 1) {location.href ="{{route("admin.node.index")}}"}else {layer.msg(res.msg,{icon: 2, time:1000});}},changePid (e) {let pid = e.target.value || 0;this.info.pid = pid;}},mounted() {}})</script></body></html>

 

1.3、添加节点控制器逻辑

/** * Store a newly created resource in storage. * * @paramIlluminateHttpRequest$request * @return IlluminateHttpResponse */public function store(Request $request){// 异常处理try {// 后台验证$this -> validate($request, ["name" => "required|unique:roles,name"]);}catch (Exception $e) {return ["status" => 20002, "msg" => "验证不通过!"];}// 入库Node::create($request -> except("_token"));return ["status" => 1, "msg" => "添加节点成功!"];}

 

1.4、模型中定义修改器

<?phpnamespace AppModels;use IlluminateDatabaseEloquentModel;class Node extends Base{//模型中定义修改器 设置route_name 可以为null方法名set+字段名驼峰式public function setRouteNameAttribute($value){// 如果字段值为null,则设置为空字符串,修改和添加时生效 store 或 update$this->attributes["route_name"] = empty($value) ? "" : $value;}}

 

1.5、效果:

到此这篇关于laravel结合vue添加权限的实现示例的文章就介绍到这了,更多相关laravel vue添加权限内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

php中cookie与session的区别点总结

本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑无论是在系统运维还是 PHP 开发人员的面试中,经常会被问到 Session 和 Cookie 在 PHP 中的区别?下面我们就...

高防服务器使用过程中出现网络卡原因有哪些?国内100G高防服务器适合哪些行业购买?

高防服务器购买使用延迟大顿的的原因有:1、本地网络出现故障;2、本地与高防服务器间的网络链路出现故障;3、dns解析出现故障;4、高防服务器配置过低,导致运用信息处理负荷过高,从而使高防服务器延迟大顿...

租韩国服务器多少钱一个月

租韩国服务器多少钱一个月?租用韩国服务器的价格是由多种因素共同影响的,以下是一些主要的因素:服务器性能:服务器的性能决定了它的承载能力和处理速度,通常来说,性能越高的服务器租用费用就越贵。网络带宽:网...

图文详解laravel多对多关联模型

关联模型(多对多)多对多关系(抽象)例:一篇文章可能有多个关键词,一个关键词可能被多个文章使用。 关键词表:字段id主键字段keyword关键词文章与关键词的关系表: 字段id主键----字...

解决启动php-fpm后访问不到php文件的办法

问题场景:linux系统nginx服务器安装好了fpm的php7在nginx的web目录下新建了index.php文件,内容为phpinfo()函数。(如果是源码安装,位置一般为 /usr/local...

阿里云服务器搭建Php+Apache运行环境的详细过程

1.apache1.1 安装apache使用yum命令安装 :yum -y install httpd执行结果如下:1.2 开启apache开启apache:systemctl start httpd...