文章目录

  • 一. Jetstream简介
    • 1. Livewire + Blade
    • 2. Inertia.js + Vue
  • 二. Jetstream + Inertia安装
    • 1. JetStream安装
    • 2. Inertia组件安装
    • 3. npm install
    • 4. npm run dev
    • 5. 数据库迁移
    • 6. 完成

一. Jetstream简介

Laravel 8 引入 Jetstream 作为前端 UI 库, Jetstream 是一个为下一代 Laravel 项目全新设计的前端 UI 扩展包,提供了基本的用户认证相关功能,并提供了两个必要的前端开发技术栈供我们选择。

1. Livewire + Blade

好处是不需要学习 Vue、React 等前端框架,可以完全使用 PHP 代码编写页面组件),同时默认兼容的 CSS 框架也从 Bootstrap 切换到了 Tailwind

2. Inertia.js + Vue

Inertia.js 支持利用现有服务端框架路由和控制器(目前支持 Laravel 和 Rails 框架),在客户端基于 JavaScript 框架编写组件(目前支持 React、Vue、Svelte)来快速构建单页面应用,因此它不是一个新框架,而是通过适配器粘合前后端框架的「胶水」,构建 Inertia 单页面应用也不像传统的 Vue 单页面应用,我们可以使用现有 Laravel 应用的后端路由来取代 Vue Router,除此之外,依然可以使用 Vue 框架其它的强大功能来构建页面组件,换言之,我们可以使用 Laravel + Vue 编写单页面应用但无需了解复杂的客户端路由技术,在这个技术栈中,Vue 退化成了纯模板语言。

我们将基于 Laravel + Vue 框架进行项目开发,所以使用Jetstream提供的 Inertia.js + Vue作为开发前端组件的技术栈。

二. Jetstream + Inertia安装

1. JetStream安装

为了提高下载速度,先将项目的composer源改为阿里云

composer config repo.packagist composer https://mirrors.aliyun.com/composer/

引入Jetstream模块

composer require laravel/jetstream

安装好jetstream模块之后,之前使用的登录测试页面会报错:

http://homestead.win/test/123123
Class "Inertia\Inertia" not found

估计是因为中间件被加入了Inertia,而我们还没安装好的缘故。

2. Inertia组件安装

php artisan jetstream:install inertia

这一步安装好之后,之前的首页刷新下可以发现错误被改变了。

Table 'homestead.sessions' doesn't exist

说明inertia中间件已经安装好,只是因为session被改成了走DB途径,而对应DB表格还没有迁移好,所以报错。
这一步会追加很多的新文件进来,而且会修改package.json,这个有点类似composer.json,是为了给下一步使用的。

3. npm install

此时,项目文件中并没有 node_modules文件夹。
执行npm install后,npm会根据package.json配置文件中的依赖配置下载安装。

注意一下,win版本模拟器,可能会遇到下载安装失败,错误有两种:

  1. enoent ENOENT: no such file or directory, open ‘/home/vagrant/Laravel/Projects/laravel-project-win/code/node_modules/cssnano-util-raw-cache/node_modules/supports-color/package.json.1846535492’
    npm ERR! enoent This is related to npm not being able to find a file
    这种我也没找到原因,不过发现,将npm升级之后,很大概率会成功。可能是版本问题吧。
sudo npm install npm -g
  1. syscall symlink
    这个报错是因为win版本虚拟机不支持软连接,而npm需要借助这个。所以这里需要将命令修改为
npm install --no-bin-links

4. npm run dev

如果是Mac机器的虚拟机,这里直接执行就好了。但是对于Win这里还有点bug。
package.json文件里定义的development:‘mix’,npm会报错。
这里需要改成laravel7版本的内容:

"dev": "npm run development",
"development": " NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --config=node_modules/laravel-mix/setup/webpack.config.js",
"watch": "npm run development -- --watch",
"watch-poll": "npm run watch -- --watch-options-poll=1000",
"hot": " NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --disable-host-check --config=node_modules/laravel-mix/setup/webpack.config.js",
"prod": "npm run production",
"production": " NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --config=node_modules/laravel-mix/setup/webpack.config.js"

修改后执行:

npm run dev -no-bin-links

成功后打印:

   Laravel Mix v6.0.13
✔ Compiled Successfully in 17480ms/js/app.js │ 1.9 MiBcss/app.css │ 3.88 MiB
webpack compiled successfully

5. 数据库迁移

这个直接执行就好了,没坑

php artisan migrate

6. 完成

重新打开首页,可以发现首页右上角多出来两个链接,login和register
至此,基于JetStream的登录模块已经集成进来了。

Laravel开发系列四:安装JetStream相关推荐

  1. WordPress版微信小程序开发系列(二):安装使用问答

    自WordPress版微信小程序发布开源以来,受关注的程度超过我原来的想象.这套程序主要面对的用户是wordpress网站的站长,如果wordpress站想在微信的生态圈得到推广,小程序成为一种重要的 ...

  2. BizTalk 开发系列(四十二) 为BizTalk应用程序打包不同的环境Binding

    更多内容请查看:BizTalk动手实验系列目录                       BizTalk 开发系列 我们在使用微软或者其他公司提供的BizTalk应用程序MSI包的时候经常会有一个目 ...

  3. 微信小程序开发系列四:微信小程序之控制器的初始化逻辑

    微信小程序开发系列教程 微信小程序开发系列一:微信小程序的申请和开发环境的搭建 微信小程序开发系列二:微信小程序的视图设计 微信小程序开发系列三:微信小程序的调试方法 这个教程的前两篇文章,介绍了如何 ...

  4. 微信小程序开发系列 (四) :微信小程序的页面跳转路由设计

    笔者由于工作需要,曾经参加过一个微信小程序同 SAP 系统集成的项目,因此从零开始学习了微信小程序的开发知识.这里通过系列文章把自己所学分享出来,希望对相关学习者有所帮助. 本教程前面三篇文章: 微信 ...

  5. s3c2410上搭建QT/Embedded4.8.5开发环境(四)--安装intel-x86 X11平台qt库qt-everywhere-opensource-src-4.8.5...

    [目标板]s3c-2410 [虚拟机]CentOS6.4 kernel-2.6.32 [编译器]gcc-4.4.6 目前QT官网的4.8.5的几个版本中Qt libraries 4.8.5 for L ...

  6. 数据处理系列(四) 安装Elasticsearch用以存储和查询数据

    为什么80%的码农都做不了架构师?>>>    准备工作 ### 添加一个额外用户用以启动 Ela 因为Ela不支持root启动adduser tmp## 设置密码 passwd t ...

  7. web控件开发系列(四) 自定义控件属性(下)

    控件在WEB开发时经常要用到,虽然有部分已经存在工具箱里,但有时总需要根据自己的要求,开发一些合适自己的控件.接上一节,已经说过了控件的属性, 例如,我们需要一组属性的集合时,这时我们需要用到的就是复 ...

  8. BizTalk 开发系列(四十) BizTalk WCF-SQL Adapter读取SQL Service Broker消息

    SQL Service Broker 是在SQL Server 2005中新增的功能.Service Broker 为 SQL Server 提供队列和可靠的消息传递,可以可用来建立以异步消息为基础的 ...

  9. ASP.net控件开发系列(四)

    属性与属性窗格 在上篇文章中,和大家探讨了属性和aspx文件中的HTML style 标签和文本的关系,遗漏了两点: 1.EnCodedInnerDefaultProperty和InnerDefaul ...

最新文章

  1. 05定制后台和修改模型
  2. PIC单片机学习之独立按键
  3. mysql 5.7解压缩_mysql 5.7.22 解压缩安装
  4. MATLAB-矩阵相关计算(1)
  5. 编码 Unicode utf-8
  6. pythonlocust使用方法_使用python的locust库进行性能测试
  7. javascript 等待指定时间_javascript的单线程和任务队列
  8. neo4j python_Python 操作 Neo4j 数据库!
  9. python的sdk是什么意思_python sdk
  10. OSChina 周一乱弹 —— 程序员的浪漫你不懂
  11. 2020 版 Python 数据清理终极指南!
  12. oracle9i怎样管理数据,数据库教程
  13. 二元函数极值问题:最小二乘法
  14. 软件质量保证与测试期末复习整理
  15. BeyondCompare3提示许可密钥过期完美解决方法
  16. php+redis+保存多个值,php向redis list一次性lPush多个值
  17. python中xlrd.open_workbook_python处理exce方法:xlrd、openyxl
  18. ADB投屏_手机无需安装客户端的【安卓投屏】
  19. 如何将 CHM 文件翻译成中文
  20. 分享一篇关于陌生人社交的竞品分析报告(上)

热门文章

  1. mysql 以什么结尾查询_MySQL查询选择以某些字符/数字结尾的列值?
  2. PS技能后期制作梦幻效果——奥顿效果(The Orton Effect)
  3. 以色列AI营养数据公司获800万美元A轮融资
  4. 搭建新浪SAE服务器
  5. 【信息技术】【2005】基于互信息的数字化重建射线照片与电子束图像配准
  6. QQ 微信 第三方登录 分享
  7. 亚马逊站電氣水族器材UL1018测试报告
  8. Linux下同时打开编辑多个文件 【VSP、vim -o】
  9. 在 E:\db\Custom\201610211635.bak 上读取失败: 38(已到文件结尾。) (Microsoft SQL Server,错误: 3203)
  10. u-boot for tiny210 version2.0(by liukun321咕唧咕唧)