详解将数据从Laravel传送到vue的四种方式


Posted in PHP onOctober 16, 2019

在过去的两三年里,我一直在研究同时使用 Vue 和 Laravel 的项目,在每个项目开发的开始阶段,我必须问自己 “我将如何将数据从 Laravel 传递到 Vue ?”。这适用于 Vue 前端组件与 Blade 模板紧密耦合的两个应用程序,以及运行完全独立于 Laravel 后端的单页应用程序。

这里有四种不同的方法从一个到另一个获取数据。

直接回显到数据对象或组件属性中

详解将数据从Laravel传送到vue的四种方式

  • 赞成: 简单明了
  • 反对: 必须与嵌入到 Blade 模板中的 Vue 应用程序一起使用

可以说是将数据从 Laravel 应用程序移动到 Vue 前端的最简单方法。使用上面的任何一种方法,您都可以将 JSON 编码的数据回送给您的应用程序或其组件。

然而,最大的缺点是可扩展性。您的 JavaScript 需要直接暴露在模板文件中,以便引擎可以呈现您的数据。如果您使用 Vue 向 Laravel 站点的页面或区域添加一些基本的交互,这应该不是问题,但是您很容易就会遇到将数据强制放入压缩脚本的困难。

详解将数据从Laravel传送到vue的四种方式

对于 Laravel 5.5+ 使用 json 指令:

使用自定义组件和 Laravel 自身的 json blade 指令可以让您轻松地将数据移动到道具中。此方法允许您划分 Vue 代码,将脚本与 Webpack 或 Mix 捆绑在一起,同时仍可以直接向其中注入数据。

将属性作为全局窗口注入

详解将数据从Laravel传送到vue的四种方式

  • 赞成: 在整个 Vue 应用程序和任何其他脚本中全局可用
  • 反对: 可能很混乱,通常不建议用于大型数据集

虽然这看起来有点老生常谈,但将数据添加到窗口对象中可以轻松地创建全局变量,这些变量可以从应用程序中使用的任何其他脚本或组件访问。在过去,我用它作为存储和访问 API 基 URL、公钥、特定模型 ID 和各种其他需要在整个前端使用的小数据项的方法。

不过,使用此方法有一点需要注意,这就是访问 Vue 组件内部数据的方式。在模板内部,您将无法使用以下内容,因为 Vue 假定您尝试访问的窗口对象位于同一组件内:

// 不会起作用
<template>
  <div v-if="window.showSecretWindow">
    <h1>这是个秘密窗口,别告诉任何人!</h1>
  </div>
</template>

相反,您需要使用返回值的计算方法:

// 会起作用
<template>
  <div v-if="showSecretWindow">
    <h1>这是个秘密窗口,别告诉任何人!</h1>
  </div>
</template>
<script>
  export default {
    computed: {
      showSecretWindow() {
        return window.showSecretWindow;
      }
    }
  }
</script>

如果这个方法的用例是较小的字符串或数值,并且使用 Laravel 自身的 mix 来编译,那么事情实际上会变得非常简单。您可以使用 process.env 对象引用 JavaScript 中 .env 文件中的值。例如,如果我的环境变量文件中有 API_DOMAIN=example.com,我可以在我的 Vue 组件(或使用 mix 编译的其他 JavaScript )中使用 process.env.API_DOMAIN。

将 API 与 Laravel 自身的 web 中间件和 CSRF 令牌一起使用

详解将数据从Laravel传送到vue的四种方式

  • 赞成: 易于启动,非常适合单页应用程序
  • 反对: 要求前端由 Blade 模板呈现

对我来说,这个解决方案是 Vue 前端 + Laravel 后端世界中最简单的入门方法。 Laravel 提供了两个不同的路由文件:web.php 和 api.php。它们被拉入并通过应用程序 Providers 目录中的 RouteServiceProvider.php 文件映射。默认情况下,web 组的中间件设置为 web,api 组的中间件设置为 api。

追溯到 app/Http/Kernel.php;您会注意到,在第 30 行左右,有两个组被映射到一个数组中,这个 web 组包含会话、 cookie 加密和 CSRF 令牌验证等内容。同时,api 组只有一个基本的限制和一些绑定。如果您的目标只是通过一个基本的、轻量级的 api 将信息拉入 Vue ,而这个 api 不需要身份验证或 post 请求,那么您可以到此为止。否则,可以进行一次修改,以确保在几秒钟内与 Vue 完全兼容。

回到上面的  RouteServiceProvider, 交换出 web 方法中的 api 中间件。我们为什么要这样做?这样做有什么作用吗?它使我们通过 api 拉入的路由也可以包含应用程序的常规网络路由通常会使用到的所有会话标量和令牌。当使用 axios 或者其他异步 JavaScript http 调用的时候,我们可以在后端使 Auth::user () 或者其他的验证技术,而默认的 api 就无法做到这些。

这个方法唯一警告的是,你必须使用 Laravel 和 一个 blade 模板来渲染前端。这样框架可以将必要的会话令牌和变量注入到请求当中。

使用 JWT 认证的 API 调用

详解将数据从Laravel传送到vue的四种方式

  • 赞成: 最安全和解耦的选项
  • 反对: 需要安装以及配置第三方程序包

JSON Web Tokens 是安全的,易于使用的方法来锁定对 API 端点的访问,并使用了 Tymon'sjwt-auth 扩展包,在这个基础上,用来构建新的项目或者在现有的 Laravel 应用中使用绝对是一件简单的事情。

要在 API 上安装和配置此功能,只需要几个简单的步骤:

  1. 在你的应用根目录运行  composer require tymon/jwt-auth。在写这篇文章的时候正处于过渡时期,因此你可能需要指定版本 (例如 1.0.0-rc.5)。
  2. 如果你使用的是 Laravel5.4 及更低的版本,将该行 Tymon\JWTAuth\Providers\LaravelServiceProvider::class, 加入 config/app.php 的 providers 数组当中。
  3. 通过运行 php artisan vendor:publish 来选择 jwt-auth 软件包发布配置文件。
  4. 运行 php artisan jwt:secret 以生成签名应用程序令牌所需要的密钥。

完成之后,你需要决定哪些路由将受 JWT 保护并针对 JWT 进行身份验证。你可以使用内置的 api auth 中间件来执行此操作,或者也可以自己滚动在发送请求的过程中获取令牌。在 API 的登录方法中,你将使用相同的 auth()->attempt 方法作为默认的 Laravel 应用程序,但从它返回的除外是你应该传递回的 JSON Web Token 令牌。

从那里,你的 Vue 应用程序应该存储该令牌 (存储在 LocalStorage 或者 Vuex),在每一个传出请求中,都将它加入到 Authorization header 作为授权头。回到你的 Laravel 应用,你可以使用他们的令牌来引用特定用户的请求。将应该显示给他们的数据返回回去。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
《PHP边学边教》(04.编写简易的通讯录――视频教程1)
Dec 13 PHP
PHP中函数内引用全局变量的方法
Oct 20 PHP
浅析HTTP消息头网页缓存控制以及header常用指令介绍
Jun 28 PHP
PHP实现的博客欢迎提示功能(很特别哦)
Jun 05 PHP
php中运用http调用的GET和POST方法示例
Sep 29 PHP
php返回json数据函数实例
Oct 09 PHP
jquery+php+ajax显示上传进度的多图片上传并生成缩略图代码
Oct 15 PHP
php实现singleton()单例模式实例
Nov 06 PHP
PHP实现货币换算的方法
Nov 29 PHP
PHP7匿名类用法分析
Sep 26 PHP
PHP实现动态删除XML数据的方法示例
Mar 30 PHP
PHP将英文数字转换为阿拉伯数字实例讲解
Jan 28 PHP
漂亮的thinkphp 跳转页封装示例
Oct 16 #PHP
Thinkphp页面跳转设置跳转等待时间的操作
Oct 16 #PHP
解决thinkphp5未定义变量会抛出异常,页面错误,请稍后再试的问题
Oct 16 #PHP
thinkphp5使html5实现动态跳转的例子
Oct 16 #PHP
Thinkphp5 如何隐藏入口文件index.php(URL重写)
Oct 16 #PHP
在thinkphp5.0路径中实现去除index.php的方式
Oct 16 #PHP
laravel5.0在linux下解决.htaccess无效和去除index.php的问题
Oct 16 #PHP
You might like
我的论坛源代码(三)
2006/10/09 PHP
利用递归把多维数组转为一维数组的函数
2006/10/09 PHP
php中将图片gif,jpg或mysql longblob或blob字段值转换成16进制字符串
2011/08/23 PHP
phpmyadmin配置文件现在需要绝密的短密码(blowfish_secret)的2种解决方法
2014/05/07 PHP
php ci框架中加载css和js文件失败的原因及解决方法
2014/07/29 PHP
详解thinkphp5+swoole实现异步邮件群发(SMTP方式)
2017/10/13 PHP
thinkphp框架实现路由重定义简化url访问地址的方法分析
2020/04/04 PHP
PHP程序员简单的开展服务治理架构操作详解(二)
2020/05/14 PHP
php 利用socket发送GET,POST请求的实例代码
2020/07/04 PHP
脚本吧 - 幻宇工作室用到js,超强推荐share.js
2006/12/23 Javascript
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
js实现浏览器的各种菜单命令比如打印、查看源文件等等
2013/10/24 Javascript
jQuery实现行文字链接提示效果的方法
2015/03/10 Javascript
js简单获取表单中单选按钮值的方法
2016/08/23 Javascript
js中利用cookie实现记住密码功能
2020/08/20 Javascript
JS实现图片垂直居中显示小结
2016/12/13 Javascript
jQuery图片轮播功能实例代码
2017/01/29 Javascript
关于vuex的学习实践笔记
2017/04/05 Javascript
node.JS md5加密中文与php结果不一致的解决方法
2017/05/05 Javascript
深入探究angular2 UI组件之primeNG用法
2017/07/26 Javascript
Nuxt配合Node在实际生产中的应用详解
2018/08/07 Javascript
layui结合form,table的全选、反选v1.0示例讲解
2018/08/15 Javascript
jquery获取file表单选择文件的路径、名字、大小、类型
2019/01/18 jQuery
如何用JavaScript实现功能齐全的单链表详解
2019/02/11 Javascript
layui实现左侧菜单点击右侧内容区显示
2019/07/26 Javascript
javascript设计模式 ? 备忘录模式原理与用法实例分析
2020/04/21 Javascript
[03:46]DOTA2英雄基础教程 维萨吉
2013/12/11 DOTA
python调用新浪微博API项目实践
2014/07/28 Python
Pandas之MultiIndex对象的示例详解
2019/06/25 Python
tensorflow 利用expand_dims和squeeze扩展和压缩tensor维度方式
2020/02/07 Python
python如何爬取网页中的文字
2020/07/28 Python
全球速卖通法国在线交易平台:AliExpress法国
2017/07/07 全球购物
英国助听器购物网站:Hearing Direct
2018/08/21 全球购物
手机促销活动方案
2014/02/05 职场文书
浅析Python实现DFA算法
2021/06/26 Python
python中字符串String及其常见操作指南(方法、函数)
2022/04/06 Python