laravel怎么同时连接数据库(Laravel框架实现多个视图共享相同数据的方法详解)
laravel怎么同时连接数据库
Laravel框架实现多个视图共享相同数据的方法详解本文实例讲述了Laravel框架实现多个视图共享相同数据的方法。分享给大家供大家参考,具体如下:
最近在用Laravel写一个cms,还没有完成,但是也遇到了许多难点,比如cms后台每个视图都要展示相同的导航菜单数据。
环境:
PHP 7.1
Apache 2.4
MySQL 5.7
Laravel 5.4
- 传统方法
假设使用传统的方法,应该是在每个控制器中都调用数据,然后把数据都塞给视图。
|
$menu = DB::table( 'menu' )->get(); return view( 'xx' ,[ 'menu' => $menu ]); |
- 稍微优化
新建一个BaseController,然后让BaseController去获取数据,然后在每个控制器都继承BaseController,最后将数据塞到视图中。
基类
|
class BaseController{ protected $menu = null; //菜单数据 public function __construct(){ $this ->getMenu(); //获取导航菜单 } public function getMenu(){ $this ->menu = DB::table( 'menu' )->get(); } } |
A控制器
|
class AController extends BaseController{ public function index(){ return view( 'admin.index' ,[ 'menu' => $this ->menu, 'user' => $user ]); } } |
缺点:在每个控制器中都需要重新设置相同的模板的数据(menu)
- 最好优化方案
使用Laravel中的View Composers来解决这个问题
1、在App\Providers下创建一个ComposerServiceProvider类
|
<?php namespace App\Providers; use Illuminate\Support\Facades\View; use Illuminate\Support\ServiceProvider; class ComposerServiceProvider extends ServiceProvider { /** * Register bindings in the container. * * @return void */ public function boot() { // 基于类的view composer View::composer( 'admin.common.*' , 'App\Http\ViewComposers\AdminComposer' ); } /** * Register the service provider. * * @return void */ public function register() { // } } |
在boot方法中定义要监听的视图,还可以使用通配符,这里我写的是admin.common.*,如果admin.common.* 下的视图被渲染的话将会调用App\Http\ViewComposers\AdminComposer@composer 方法
2、注册ComposerServiceProvider
在config/app.php文件下的providers数组中进行注册
|
App\Providers\ComposerServiceProvider:: class , |
3、创建AdminComposer类
Laravel推荐把view composer类放在app\Http\ViewComposers目录下,这个目录一开始是没有的,需要新建
|
<?php namespace App\Http\ViewComposers; use App\Libs\CommonUtils; use Illuminate\Http\Request; use Illuminate\View\View; class AdminComposer { private $data = null; //CommonUtils对象 public function __construct(Request $request ) { $this ->data = new CommonUtils( $request ); //新建一个CommonUtils对象 } public function compose(View $view ) { $view ->with([ 'admin' => $this ->data->admin, 'mbx' => $this ->data->mbx, 'menu' => $this ->data->menu, 'msg' => $this ->data->msg ]); //填充数据 } } |
在这里我在构造方法中创建了一个对象,这个对象中包含着数据
5、CommonUtils文件
|
<?php /** * Created by PhpStorm. * User: Administrator * Date: 2017/4/20 0020 * Time: 19:49 */ namespace App\Libs; use App\Admin; use App\Perm; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; class CommonUtils { public $admin = null; //管理员对象 public $menu = null; //菜单对象 public $mbx = null; //面包屑对象 public $msg = null; //消息对象 /** * 构造函数 */ public function __construct(Request $request ) { $this ->init( $request ); } /** * 初始化函数 */ private function init(Request $request ) { $this ->getAdmin( $request ); $this ->getMsg(); $this ->getMenu( $request ); $this ->getMbx( $request ); } /** * 获取管理员数据 */ private function getAdmin() { $this ->admin = session( 'admin' ); } /** * 获取后台菜单数据 */ private function getMenu(Request $request ) { $menu = DB::table( 'menu' )->where( 'parentid' , 0)->orderBy( 'sort' )->get(); $router = $request ->getPathInfo(); $perm = new Perm(); $mbx = $perm ->getMbx( $router ); foreach ( $menu as $k => $m ) { $m ->active = '' ; //读取子菜单 $childMenu = DB::table( 'menu' )->where( 'parentid' , $m ->id)->orderBy( 'sort' )->get(); if ( count ( $childMenu ) > 0) { foreach ( $childMenu as $v ){ $v ->active = '' ; if ( $mbx [0]->router == $v ->router){ $v ->active = 'active' ; $m ->active = 'active' ; } } $m ->childMenu = $childMenu ; } else { $m ->childMenu = null; } } $this ->menu = $menu ; } /** * 获取面包屑 */ private function getMbx(Request $request ) { $router = $request ->getPathInfo(); $perm = new Perm(); $mbx = $perm ->getMbx( $router ); $this ->mbx = $mbx ; } /** * 获取未读消息 */ private function getMsg() { $adminModel = new Admin(); $toId = $this ->admin->id; $this ->msg = $adminModel ->getUnReadMsg( $toId ); } } |
在这里面分别获取了管理员、菜单、面包屑、消息数据,这些数据都是每个后台页面都要使用到的。
注意:这里我将类定义成了CommonUtils,感觉名字取得不好,CommonUtils是存放在App\Libs下的,这个Libs文件夹是我新建的,用于存放工具类的。如果需要给App\Libs文件夹添加自动加载,需要在composer.json文件里做如下修改。
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/baochao95/article/details/70313799
- laravel获取数据(laravel框架添加数据,显示数据,返回成功值的方法)
- laravel数据库切换(实现laravel 插入操作日志到数据库的方法)
- laravel5开发规范(laravel5.1框架基础之路由详解)
- php框架laravel使用(laravel5环境隐藏index.php后缀apache的方法)
- laravel命令行与可选项(Laravel6.0.4中将添加计划任务事件的方法步骤)
- echart图表有哪些(使用laravel和ECharts实现折线图效果的例子)
- laravel关联模型新增数据(使用laravel的migrate创建数据表的方法)
- laravel 后台管理框架(关于Laravel-admin的基础用法总结和自定义model详解)
- laravel数据库操作方式(Laravel 实现数据软删除功能)
- laravel前后端分离实现排序(laravel自定义分页的实现案例offset和limit)
- laravel框架运行找不到视图(解决laravel资源加载路径设置的问题)
- 安装laravel框架(laravel框架的安装与路由实例分析)
- laravel的验证规则(解决在Laravel 中处理OPTIONS请求的问题)
- laravel服务器设置教程(laravel框架模型、视图与控制器简单操作示例)
- laravel框架学习心得教程(Laravel5.7 Eloquent ORM快速入门详解)
- laravel后台登录教程(Laravel 默认邮箱登录改成用户名登录的实现方法)
- 香蕉(香蕉三种人不宜吃)
- 没钱可以快乐吗(没钱也能快乐吗)
- 快乐是什么(快乐就是)
- 东南亚有哪个国家(东南亚有哪个国家最发达)
- 东南亚安全吗(好不好挣钱)
- 潘长江小品《照亮全家福》台词剧本完整版(潘长江小品照亮全家福台词剧本完整版)
热门推荐
- docker部署mysql多实例(Docker部署mysql一主一从的操作方法)
- 创建数据表的sql语句代码(用注解编写创建表的SQL语句)
- 如何用xampp新建数据库(Windows系统下XAMPP的安装配置图文教程)
- Visual studio中使用VSCommands插件在大括号尾部显示方法或过程名字
- nodejs实现websocket服务端(Node.js+express+socket实现在线实时多人聊天室)
- CSS网页布局的几个建议
- python语言提供的3种基本数据类型(详解Python3 基本数据类型)
- javascript写计算器教程(基于JavaScript实现简易计算器)
- 阿里云服务器如何选(企业如何选择阿里云服务器配置?)
- python3有哪些内置模块(Python3.5内置模块之os模块、sys模块、shutil模块用法实例分析)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9