如果您对如何在Laravel6.x.中使用组件?和laravel常用组件感兴趣,那么这篇文章一定是您不可错过的。我们将详细讲解如何在Laravel6.x.中使用组件?的各种细节,并对laravel常用
如果您对如何在 Laravel 6.x. 中使用组件?和laravel常用组件感兴趣,那么这篇文章一定是您不可错过的。我们将详细讲解如何在 Laravel 6.x. 中使用组件?的各种细节,并对laravel常用组件进行深入的分析,此外还有关于javascript – 如何在laravel刀片中使用vue.js组件?、laravel – 如何在vue js中将数据从一个组件传递到另一个组件?、Laravel 如何在blade文件中使用Vue组件、laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy的实用技巧。
本文目录一览:- 如何在 Laravel 6.x. 中使用组件?(laravel常用组件)
- javascript – 如何在laravel刀片中使用vue.js组件?
- laravel – 如何在vue js中将数据从一个组件传递到另一个组件?
- Laravel 如何在blade文件中使用Vue组件
- laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy
如何在 Laravel 6.x. 中使用组件?(laravel常用组件)
如何解决如何在 Laravel 6.x. 中使用组件??
我想创建一个组件;但是,它不起作用,我收到了 500 内部服务器错误。
@component(''components.pulldown'')
@endcomponent
作为一种解决方法,我改用 Blade 指令 @extend
。但是,它只显示页面的上侧。有人可以请教吗?
@foreach ($users as $user)
<tr>
<td>
{{ $user->id }}
</td>
<td>
{{ $user->name }}
</td>
@if($user->country)
<td>
{{ $user->country }}
</td>
@else
<td>
Select @extends(''components.pulldown'')
</td>
@endif
</tr>
@endforeach
<select name="countries">
<option value="US">US</option>
<option value="UK">UK</option>
<option value="EU">EU</option>
<option value="JP">Japan</option>
</select>
解决方法
使用@include 代替@extend。这将解决问题。有关 Laravel 组件的更多详细信息,请访问此链接:here
javascript – 如何在laravel刀片中使用vue.js组件?
我在我的app.js中注册了这样的组件:
Vue.component('navbar', require('./components/Navbar.vue'));
现在我要导入该组件:
<template>
<nav>CODE HERE</nav>
</template>
进入我的blade.PHP文件:
<body>
<div id="app">
<div>
<navbar></navbar> <-- here!
@yield('content')
</div>
</div>
</body>
最简单的方法是什么?
解决方法:
在app.js
import navbar from './components/Navbar.vue';
Vue.component('navbar', require('./components/Navbar.vue'));
var app = new Vue({
el: '#app',
components: {
'navbar': require('./components/Navbar.vue'),
}
});
在你的刀片中:
<body>
<div id="app">
<div>
<navbar></navbar>
@yield('content')
</div>
</div>
laravel – 如何在vue js中将数据从一个组件传递到另一个组件?
这是第一个和第二个组件的代码.
SelectPerson.vue
<template> ...... <div> <input type="number"name="numberOfPersons" placeholder="Enter number of persons here" **v-model="inputPersons"**> <br> **<SelectTimeSlot v-bind:numberOfPersons="inputPersons"></SelectTimeSlot>** </div> <div> <buttonv-on:click="selectTimeSlots">Next</button> </div> ...... </template> <script> import SelectTimeSlot from './SelectTimeSlot.vue' export default{ props:['numberOfPersons'],data(){ return{ **inputPersons:0** } },methods:{ selectTimeSlots(){ this.$router.push({name:'SelectTimeSlot'}); } } } </script>
第二部分
SelectTimeSlot.vue
<template> <h5>Welcome,You have selected **{{numberOfPersons}}** persons.</h5> </template>
有人可以帮我吗?
解决方法
第一部分:
<second-component-name :selectedOption="selectedOption"></second-component-name> <script> export default { components: { 'second-component-name': require('./secondComponent.vue'),},data() { return { selectedOption: '' } } } </script>
第二部分:
<template> <div> {{ selectedOption }} </div> </template> <script> export default { props: ['selectedOption'] } </script>
请访问this link.
希望这对你有所帮助!
Laravel 如何在blade文件中使用Vue组件
Laravel 如何在blade文件中使用Vue组件
1. 安装laravel/ui依赖包
composer require laravel/ui
2.生成vue基本脚手架
php artisan ui react
系统还提供了非常便捷的auth脚手架,带登录注册。
php artisan ui react --auth
3.组件位置
Vue组件ExampleComponent.vue将被放置在resources/js/components目录中。ExampleComponent.vue文件是单个文件Vue组件的示例,该组件在同一文件中定义其JavaScript和HTML模板。单个文件组件为构建JavaScript驱动的应用程序提供了一种非常方便的方法。该示例组件已在您的app.js文件中注册:
Vue.component(
''example-component'',
require(''./components/ExampleComponent.vue'').default
);
4.在blade模版中使用
要在应用程序中使用该组件,您可以将该组件放入Blade模板xxx.blade.php中:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>@yield(''title'')</title>
<link rel="stylesheet" href="{{mix(''/css/app.css'')}}">
</head>
<body>
<divid="app">
<example-component></example-component>
</divid=>
<script src="{{mix(''/js/app.js'')}}"></script>
</body>
</html>
注意:在blade文件中一定要有id为app的根节点,而且把组件放到里面,才能生效!!!
本文由博客一文多发平台 OpenWrite 发布!
laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy
这两天项目中需要将HTML页面转换为PDF文件方便打印,我在网上搜了很多资料。先后尝试了laravel-dompdf和laravel-snappy两种扩展包,个人感觉laravel-snappy比较好用。
一、使用laravel-dompdf扩展包
1、安装扩展包
我们通过composer来安装
composer require barryvdh/laravel-dompdf
2、将ServiceProvider添加到config / app.php中的providers数组中
Barryvdh\DomPDF\ServiceProvider::class,
3、添加facade到config / app.php中的aliases数组中
''PDF'' => Barryvdh\DomPDF\Facade::class,
4、使用
可以创建一个dompdf实例并加载HTML字符串、文件或者视图,然后使用stream()方法显示在浏览器中、save()方法保存到文件或者download()方法下载。
$pdf = App::make(''dompdf.wrapper'');
$pdf->loadHTML(''<h1>Test</h1>'');
return $pdf->stream();
也可以使用门面(facade),使用前先use PDF;
$pdf = PDF::loadView(''pdf.invoice'', $data);
return $pdf->download(''invoice.pdf'');
也可以链式操作
return PDF::loadFile(public_path().''/myfile.html'')->save(''/path-to/my_stored_file.pdf'')->stream(''download.pdf'');
可以更改方向(landscape将方向设为横向,一般使用的都是竖向的,使用时注意一下)和纸张大小,并隐藏或显示错误(默认情况下,调试打开时显示错误)
PDF::loadHTML($html)->setPaper(''a4'', ''landscape'')->setWarnings(false)->save(''myfile.pdf'')
其他的一些基本使用和配置请参考文档资料https://github.com/barryvdh/laravel-dompdf
5、解决中文乱码问题
下载一个支持unicode编码的中文字体。例如:msyh.ttf(微软雅黑)
建议先在storage下创建fonts文件夹,把字体放在fonts文件夹下,不然会报错。
在css中引入字体
<style>
@font-face {
font-family: ''msyh'';
font-style: normal;
font-weight: normal;
src: url({{ storage_path(''your_path/msyh.ttf'') }}) format(''truetype'');
}
body {
font-family: msyh, DejaVu Sans,sans-serif;
}
</style>
注意:亲测只有unicode编码的中文,才能正常显示,这也是我觉得这个PDF扩展不太好用的原因。
二、使用laravel-snappy扩展包
1、安装依赖软件
laravel-snappy扩展包需要Wkhtmltopdff的支持,所以先安装Wkhtmltopdf
方法一:下载wkhtmltopdf安装包
wkhtmltopdf下载地址http://www.softpedia.com/get/Office-tools/PDF/wkhtmltopdf.shtml
windows直接下载安装就可以了,注意安装到你知道的地方,这个路径后面有用。
我的安装在G:wk目录下
在bin目录下有wkhtmltoimage与wkhtmltopdf两个依赖软件
linux下载解压完成后,要将文件移动到 /usr/local/bin 下
方法二:通过 composer 来安装
以linux系统为例

32位:
$ composer require h4cc / wkhtmltopdf-i386 0.12.x
$ composer require h4cc / wkhtmltoimage-i386 0.12.x,
64位:
$ composer require h4cc/wkhtmltopdf-amd64 0.12.x
$ composer require h4cc/wkhtmltoimage-amd64 0.12.x
(uname -a 命令查看系统位数)
cp vendor/h4cc/wkhtmltoimage-amd64/bin/wkhtmltoimage-amd64 /usr/local/bin/
cp vendor/h4cc/wkhtmltopdf-amd64/bin/wkhtmltopdf-amd64 /usr/local/bin/
并使其可执行:
chmod +x /usr/local/bin/wkhtmltoimage-amd64
chmod +x /usr/local/bin/wkhtmltopdf-amd64

Linux 下使用该第三方插件需要几个库的支持
apt-get install libXrender*
apt-get install libfontconfig*
1、安装laravel-snappy扩展包
composer require barryvdh/laravel-snappy
2、将ServiceProvider添加到config / app.php中的providers数组
Barryvdh\Snappy\ServiceProvider::class,
3、添加facade到config / app.php中的aliases数组中
''PDF'' => Barryvdh\Snappy\Facades\SnappyPdf::class,
''SnappyImage'' => Barryvdh\Snappy\Facades\SnappyImage::class,
4、生成配置文件
php artisan vendor:publish --provider="Barryvdh\Snappy\ServiceProvider"
此命令会在config/snappy.php生成配置文件
具体配置如下:
<?php
return array(
''pdf'' => array(
''enabled'' => true,
// ''binary'' => ''/usr/local/bin/wkhtmltopdf'', //依赖软件的路径,linux默认在此目录下
''binary'' => ''G:\wk\wkhtmltopdf\bin\wkhtmltopdf'',
''timeout'' => false,
''options'' => array(),
''env'' => array(),
),
''image'' => array(
''enabled'' => true,
// ''binary'' => ''/usr/local/bin/wkhtmltoimage'',
''binary'' => ''G:\wk\wkhtmltopdf\bin\wkhtmltoimage'',
''timeout'' => false,
''options'' => array(),
''env'' => array(),
),
);
5、使用 ( 与使用dompdf类似 )
先引入
use PDF;
use SnappyImage;
生成PDF文件
可以使用门面(facade)加载HTML字符串、文件或者视图,然后使用stream()方法显示在浏览器中、save()方法保存到文件或者download()方法下载。
$pdf = PDF::loadView(''pdf.invoice'', $data);
return $pdf->download(''invoice.pdf'');
也可以链式操作
return PDF::loadFile(public_path().''/myfile.html'')->save(''/path-to/my_stored_file.pdf'')->stream(''download.pdf'');
可以更改方向(landscape将方向设为横向,一般使用的都是竖向的,使用时注意一下)和纸张大小,并隐藏或显示错误(默认情况下,调试打开时显示错误)
PDF::loadHTML($html)->setPaper(''a4'', ''landscape'')->setWarnings(false)->save(''myfile.pdf'')
生成图片
$pdf = SnappyImage::loadView(''pdf.invoice'', $data);
return $pdf->download(''invoice.image'');
6、解决中英文乱码问题 (linux)
可以将例如:宋体或其他中文字体添加到 /usr/share/fonts/ 里
非常开心能够将我的学习心得分享给大家 (๑><๑)
今天的关于如何在 Laravel 6.x. 中使用组件?和laravel常用组件的分享已经结束,谢谢您的关注,如果想了解更多关于javascript – 如何在laravel刀片中使用vue.js组件?、laravel – 如何在vue js中将数据从一个组件传递到另一个组件?、Laravel 如何在blade文件中使用Vue组件、laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy的相关知识,请在本站进行查询。
本文标签: