GVKun编程网logo

如何在 Laravel 6.x. 中使用组件?(laravel常用组件)

5

如果您对如何在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常用组件)

如何在 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组件?

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中将数据从一个组件传递到另一个组件?

laravel – 如何在vue js中将数据从一个组件传递到另一个组件?

我正在学习vue laravel.我想将值从一个组件传递到其他组件?我已经使用vue路由器进行路由.

这是第一个和第二个组件的代码.
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>

有人可以帮我吗?

解决方法

要将数据从一个组件传递到其他组件,您需要使用props:

第一部分:

<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组件

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>

file

注意:在blade文件中一定要有id为app的根节点,而且把组件放到里面,才能生效!!!

本文由博客一文多发平台 OpenWrite 发布!

laravel中使用的PDF扩展包——laravel-dompdf和laravel-snappy

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的相关知识,请在本站进行查询。

本文标签: