laravelwith合并,laravel扩展

http://www.itjxue.com  2023-01-17 18:50  来源:未知  点击次数: 

请教laravel view 怎么显示 controller 中传递的对象值

你应该学习下 blade模板

Blade 模板引擎

简介

Blade 是 laravel 提供的一个简单强大的模板引擎。它不像其他流行的 PHP 模板引擎那样限制你在视图中使用原生的 PHP 代码,事实上它就是把 Blade 视图编译成原生的 PHP 代码并缓存起来。缓存会在 Blade 视图改变时而改变,这意味着 Blade 并没有给你的应用添加编译的负担。Blade 视图文件使用 .blade.php 后缀,一般情况下都被存储在 resources/views 目录。

模板继承

定义布局

Blade 带来的两个主要的福利就是模板继承和挂件。为了方便开始,我们来看一个简单的例子。首先,我们建立一个主页面布局。因为多数 web 应用是在不同的页面中使用相同的总体布局,我们可以方便的定义这个布局为单独的 Blade 视图:

!-- Stored in resources/views/layouts/master.blade.php--

html

head

titleApp Name - @yield('title')/title

/head

body

@section('sidebar')

This is the master sidebar.

@show

div class="container"

@yield('content')

/div

/body

/html

从上面的例子你可以看到,Blade 模板文件包含了典型的 HTML 标记。你肯定注意到了 @section 和 @yield 指令。@section 指令就如它的名字所暗示的那样定义了一个内容区块,而 @yield 指令是用来显示所提供的挂件区块所包含的内容。

现在我们已经定义好了一个基本的布局,接下来我们来构建一个子页面去继承这个布局。

扩展布局

我们可以使用 Blade 的 @extends 指令来明确的指定继承某个布局。然后使用 @section 指令将挂件中的内容挂载到布局中,在上面的例子中,挂件的内容将被挂载到布局中的 @yield 部分:

!-- Stored in resoures/views/child.blade.php --

@extends('layouts.master')

@section('title', 'Page Title')

@section('sidebar')

@parent

pThis is appended to the master sidebar./p

@endsection

@section('content')

pThis is my body content./p

@endsection

在上面的例子作用 sidebar 挂件利用 @parent 指令来追加布局中的 sidebar 部分的内容,如果不使用则会覆盖掉布局中的这部分。@parent 指令会在视图被渲染时替换为布局中的内容。

Blade 视图可以像原生 PHP 视图一样使用全局帮助函数 view 来返回渲染后的内容:

Route::get('blade', function () {

return view('child');

});

显示数据

你可以使用花括号 { 来在视图中显示传递到视图中的变量,例如,你定义了下面的路由:

Route::get('greeting', function () {

return view('welcome', ['name' = 'Samantha']);

})

你可以在视图中这样来输出 name 变量的内容:

Hello, {{ $name }}

当然,你并没有被限制只允许显示传递到视图中的变量的内容。你也可以从原生 PHP 方法中返回内容。事实上,你可以在 Blade echo 声明中使用任意的 PHP 代码:

The current UNIX timestamp is {{ time() }}

注意:Blade {{}} 声明中的内容是自动通过 PHP 的 htmlentities 方法过滤的,用来防止 XSS 攻击。

Blade JavaScript Frameworks

由于很多 JavaScript 框架都使用花括号来表明所提供的表达式应该被显示在浏览器中。所以你可以使用 @ 符号来告诉 Blade 渲染引擎你需要这个表达式原样保留:

h1Laravel/h1

Hello, @{{ name }}

上面的例子中,@ 符号会在 Blade 渲染时被移除,并且 {{ name }} 表达式会被原样保留下来。

输出数据假如它存在

有时候你可能希望输出一个变量,但是你并不确定它是否已经被设置,你可以使用这个表达式:

{{ isset($name) ? $name : 'Default' }}

Blade 提供了一个便捷的方式来替换这个三元声明:

{{ $name or 'Default' }}

上面的例子中,如果变量 $name 存在,它将被输入,如果不存在,Default 会被输出。

显示未转义的数据

默认的,Blade {{}} 声明会自动的使用 PHP 的 htmlentities 方法来避免 XSS 攻击。如果你不想你的数据被转义,你可以使用下面的语法:

Hello, {!! $name !!}

注意:当你在应用中输出用户输入的数据时应该非常的谨慎,你应该总是使用 {{}} 来转义内容中任意的 HTML 实体。

控制结构

除了模板继承和数据显示,Blade 为通用的 PHP 控制结构提供了便利的简写方式,比如条件声明和循环。这些简写提供了一个干净简洁的方式来处理 PHP 的控制结构,而且还保持与 PHP 语句的相似性。

if 声明

你可以通过 @if,@elseif,@else和 @endif 指令来使用 if 控制结构,这些指令和 PHP 方法保持一致:

@if (count($records) === 1)

I have one record!

@elseif (count($records) 1)

I have multiple records!

@else

I don't have any records!

@endif

为了方便,Blade 也提供了 @unless 指令:

@unless (Auth::check())

You are not signed in.

@endunless

你也可以使用 @hasSection 指令来判断提供给布局的挂件是否包含了内容:

title

@hasSection('title')

@yield('title') - App Name

@else

App Name

@endif

/title

循环

除了条件声明,Blade 也提供了一些简单指令来支持 PHP 的循环结构。这些指令方法和 PHP 语法相同:

@for ($i = 0; $i 10; $i++)

The current value is {{ $i }}

@endfor

@foreach ($users as $user)

pThis is user {{ $user-id }}/p

@endforeach

@forelse ($users as $user)

li{{ $user-name }}/li

@empty

pNo users/p

@endforelse

@while (true)

pI'm looping forever./p

@endwhile

Blade 也提供了终止迭代或取消当前迭代的指令:

@foreach ($users as $user)

@if($user-type == 1)

@continue

@endif

li{{ $user-name }}/li

@if($user-number == 5)

@break

@endif

@endforeach

你也可以使用指令声明包含条件的方式来达到中断:

@foreach ($users as $user)

@continue($user-type == 1)

li{{ $user-name }}/li

@break($user-number == 5)

@endforeach

包含子视图

你可以使用 @include 指令来包含一个视图的内容,当前视图中的变量也会被共享给子视图:

div

@include('shared.errors')

form

!-- Form Contents --

/form

/div

尽管子视图会自动继承父视图中的所有数据变量,你也可以直接传递一个数组变量来添加额外的变量到子视图:

@include('view.name', ['some' = 'data'])

主要:你应该在 Blade 视图中避免使用 __DIR__ 和 __FILE__ 常量,因为它们会解析为视图缓存所在的位置。

为集合渲染视图

你可以使用 Blade 的 @each 指令来在一行中合并引入多个视图:

@each('view.name', $jobs, 'job')

第一个参数是数组或集合中每个元素需要被渲染的视图名称。第二个参数是一个数组或集合,被用来提供迭代。而第三个参数是要分配给当前视图的变量名。举个例子,如果你需要遍历一个数组 jobs,通常你想要在局部渲染的视图中使用 job 作为变量来访问 job 信息。

你也可以传递第四个参数到 @each 指令。如果所提供的数组是空数组的话,该参数所提供的视图将会被引入。

@each('view.name', $jobs, 'job', 'view.empty')

注释

Blade 也允许你在视图中定义注释,但是它不会在渲染时生成 HTML 注释:

{{-- This comment will not be present in the rendered HTML --}}

Blade 允许你在已命名的堆中压入内容:

@push('scripts')

script src="/example.js"/script

@endpush

你可以在你需要的时候压入相同的堆任意的次数,你需要在布局中使用 @stack 来渲染堆:

head

!-- Head Contents --

@stack('scripts')

/head

服务注入

你可以使用 @inject 指令来从服务容器中取回服务,该指令的第一个参数将作为所取回服务存放的变量名,而第二个参数是你想要在服务容器中取回的类或接口名称:

@inject('metrics', 'App\Services\MetricsService')

div

Monthly Revenue: {{ $metrice-monthlyRevenue() }}

/div

扩展 Blade

Blade 允许你自定义一些指令,你可以使用 directvie 方法来注册指令。当 Blade 编译器遇到该指令时,它会自动的调用该指令注册时提供的回调函数并传递它的参数。

下面的例子创建了 @datetime($val) 指令来格式化 $val:

?php

namespace App\Providers;

use Blade;

use Illuminate\Support\ServiceProvider;

class AppServiceProvider extends ServiceProvider

{

/**

* Perform post-registration booting of services.

*

* @return void

*/

public function boot()

{

Blade::directive('datetime', function ($expression) {

return "?php echo with{$express}-format('m/d/Y H:i'); ?";

});

}

/**

* Register bindings in the container

*

* @return void

*/

public function register()

{

//

}

}

上面的例子中使用了 Laravel 的 with 帮助方法,它只是简单的返回一个所提供的对象或值,并提供方便的链式调用。最终该指令生成的 PHP 代码如下:

?php echo with($var)-format('m/d/Y H:i'); ?

在你更新 Blade 指令的逻辑之后,你应该删除所有已缓存的 Blade 视图,你可以使用 view:clear Artisan 命令来清除。

作者:Dearmadman

链接:

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

laravel excel 合并单元格cell怎么读取

“excel中合并单元格如何保留单元格中的所有数据”的操作步骤是:

1、打开Excel工作表;

2、如果合并A1:B6单元格,直接选择“对齐”中的“合并单元格”,只能保留左上角的数据,而放弃其他值;

3、传统的方式合并单元格未能全部保留所有数据,因此如果需要保留所有数据到合并单元格,需要进行转换;

4、选择D1:E6单元格,在“开始”“对齐方式”的“合并”下拉选项中,选择“合并单元格”;

5、选择A1:B6单元格,按Ctrl+C,“复制”;

6、双击合并后的单元格D1:E6,使其进入编辑状态,然后点击剪贴板,并单击刚才复制的内容;

7、剪贴板中的复制数据被粘贴到了合并单元格;

8、按Enter键完成操作,光标进入下一个单元格,此时A1:B6单元格的数据全部保留在了合并单元格;

9、根据需要,删除原A1:B6,或者将D1:E6复制并粘贴到A1:B6区域,即可。

laravel重定向到上一个页面怎么带参数返回

//控制器中

return?back()-with('success','操作成功');

//with的参数1是一个session变量名,参数2为该session变量值,在视图直接这样获取

@if(!empty(session('success')))

{{session('success')}}

@endif

Laravel 中大量数据查询有什么技巧吗

-get(array('posts.id', 'posts.support', 'posts.against', 'users.username', 'posts.post_author', 'posts.post_title', 'posts.post_body'));

foreach($posts as $p){

$data[] = array(

'id' = $p - id,

'support' = $p - support,

'against' = $p - against,

'username'= $p - username,

'post_author' = $p - post_author,

'post_title' = $p - post_title,

'post_body' = $p - post_body

);

}

$res = View::make('home.index')

- with('posts', $data);

Cache::forever('staticPageCache_home', $res);

}

// 返回缓存的数据

return Cache::get('staticPageCache_home');

}

}

这里我用到了三个api

1). Cache::has ,这个判断是说如果当前不存在 staticPageCache_home 这个名字的缓存, 就立即去取数据

2). Cache::forever, 这个从用例文档里面可知是"永久缓存"的意思, 因为我一般都是很勤劳的,如果发表了博文,自己再去后台立即刷新一下缓存就好了, 所以不需要设置过期啊失效时间之类的, 当然这个是要按各自的具体需求来的

3). Cache::get , 这句是从缓存里面取出 staticPageCache_home 这个名字的缓存, 然后作为响应内容返回

嗯, 就这么简单, 呵呵, 一个基本的缓存功能就完成了, laravel的确是不错地!

3. 为后台添加刷新缓存功能

还是贴代码吧, 不过也很简单:

// 刷新首页缓存(暂时只支持首页)

public function get_refreshcache() {

/*

@var $GID admin组id

*/

$GID = 1;

if ( Auth::user() - gid === 1 ) {

$data = array();

$posts = Post::with('user')

-join('users', 'users.id', '=', 'posts.post_author')

- order_by('posts.created_at', 'desc')

-get(array('posts.id', 'posts.support', 'posts.against', 'users.username', 'posts.post_author', 'posts.post_title', 'posts.post_body'));

foreach($posts as $p){

$data[] = array(

'id' = $p - id,

'support' = $p - support,

'against' = $p - against,

'username'= $p - username,

'post_author' = $p - post_author,

'post_title' = $p - post_title,

'post_body' = $p - post_body

);

}

$res = View::make('home.index')

- with('posts', $data);

Cache::forever('staticPageCache_home', $res);

return '刷新首页缓存成功!';

}

return '对不起,只有管理员组才可进行此操作!';

}

我给后台添加了一个项目, 对应这个方法, 方法内容和首页的大同小异, 取数据, 然后Cache::forever 刷新一下缓存,就这么简单,当然了,上面的Auth::user() 判断是个简单的判断,只有管理员组才能进行刷新操作,呵呵

laravel框架中这个with函数怎么回事

这个类可能在这个地方用到了哦!~~xdebug_start_function_monitor. 给你看截图: 截图可能看不清, 一个是在ResourceOpecations.php 的getFunctions方法中声明了'php_user_filter::filter', 另一个就是这个getFunctions被调用的地方

(责任编辑:IT教学网)

更多

推荐图片影音文章