详解如何在Laravel9.x中快速安装Bootstrap
发布时间 - 2022-11-18 00:00:00 点击率:次在 Laravel 9.x 中优雅且轻松的安装 Bootstrap 框架(vite 篇)
本文给大家分享以下 laravel 9.x 下的前端工作流的使用心得,之前用 laravel mix,现在咱们这次就用用官方推荐的 vite 工具,同时继续使用 bootstrap 5,这样的话既能方便课程学者即能掌握最新的前端工作流,又能低门槛的调整自己喜欢的样式。最重要的是不影响教程的学习进度和节奏。【推荐:laravel视频教程】
写在前面
开发环境:
大环境上是 Windows 10/11 + Homestead,均为最新稳定版本
两个平台都安装 Node.js
Laravel 版本为 9.x(发文时我用的是最新的 9.38.0) ,其他未提及的按照 9.x 版本的教程来
不使用 Laravel Mix,使用官方推荐的新前端打包工具 vite 完成教程里关于样式的修改任务。
我的目的:在 Windows 和 homestead 两个平台使用 Node.js 来规避安装 Boots
trap 中能踩到的坑,让苦逼的 Win 用户学习《L01 Laravel 教程 - Web 开发实战入门》的《4.2. 样式美化》章节做到 优雅且轻松。
不多废话,线上操作
操作方法
首先默认读者已经学习到《4.2. 样式美化》章节,并且很不幸的被卡住,其次,自己的 Windows 电脑和 Homestread 环境都可以运行 Node.js。Windows 下没有装 Node.js 的可通过搜索引擎搜索下载,傻瓜式的安装流程,不再赘述。
首先我们根据教程做到下方这一步,但先别执行
composer require laravel/ui:3.4.5 --dev
我们改改,这里直接获取默认的最新 laravel/ui 版本,并在 linux 内执行
composer require laravel/ui // 发文时最新的版本是 4.0.1,对不住了版主,我自己偷摸的上到最新的版本惹 php artisan ui bootstrap
然后我们到 windows 环境下开一个终端,比如 powershell,并执行
npm config set registry=https://registry.npm.taobao.org npm i
然后回到你的编辑器,找到项目根目录下刚生成的 vite.coffig.js 我们修改成如下的效果
import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';
import path from 'path'
export default defineConfig({
plugins: [
laravel([
'resources/js/app.js',
]),
],
resolve: {
alias: {
'~bootstrap': path.resolve(__dirname, 'node_modules/bootstrap'),
}
},
});然后在 app.js 中导入 boostrap 5 的 scss
import './bootstrap'; // 以下为新增部分 import '../sass/app.scss' import * as bootstrap from 'bootstrap'
之后再去项目的 blade 模板中,更换原本的 mix () 代码。这里的话要是根据教程来,我们只改那个 default.blade.php 文件即可,即将其中的这两行代码
全部换成 @vite 代码
@vite(['resources/js/app.js'])
下面是我在 default.blade.php 放的位置
@yield('title', 'Weibo App') - Laravel 入门教程
@vite(['resources/js/app.js']) <--- here!
@yield('content')
之后我们后期学习中,但凡牵扯到 Mix 的一律按照这个思路处理。
最后,在 windows 终端输入如下指令
npm run build // 或者 npm run dev
操作结束,刷新以下浏览器就可看到效果。
至于 dev 和 build 的区分就是:
dev 适合开发的时候随时调整,你的修改是实时生效且自动的,建议开发的时候一直开个窗口挂后台就行
build 会一步处理完毕并输出 css 和 js 文件,只会执行一次不会自动,适合最后发布阶段。
速度方面,相比较 laravel Mix 前端工作流,vite 会以闪电般的速度给你稳健的处理好,放心,vite 的处理速度实在是太快惹。
项目部署
当我们的代码上传到远端 git 仓库后,再拉到生产环境时,vite 使用 npm run build 生成的 css 和 js 文件是不会纳入 git 管理的,也就是你在本地 git add -A 是包括不了他俩的,我们需要在本地开发项目的根目录找到.gitignore 文件,注释或者删除 /public/build 这一行,具体如下
/node_modules # /public/build <-- here /public/hot /public/storage /storage/*.key /vendor .env .env.backup .phpunit.result.cache Homestead.json Homestead.yaml auth.json npm-debug.log yarn-error.log /.idea /.vscode
之后我们 build 的文件就可以被 git add -A 检测到。
当然,你也完全可以在线上编译样式,这个思路你懂就行,举一反三嘛。
其他小贴士
bootstrap 5 已经删除原本 4 版本的 Jumbotron 组件,所以你看不到对应的样式,正常现象。想改的请发挥自己的想象,去自己写一个。
关于 4.4. 浏览器缓存问题 章节,若你使用 vite 的前端工作流,build 完毕后,会自动给样式文件加上后缀,所以这一章节可以不看,使用 vite 的工作模式是不存在这个问题的,跳过继续学习。
是否发现本文有些地方你可以提出你自己的方法,这样最好,我的回答不是最完美的,大家学习过程中能提出自己独立思考的疑问或者解决方案,才是最棒的结果,欢迎大家探索适合自己的解决方案。
最后碎碎念
然后相比较版主教程里让我们用特定版本学习 laravel 的方法,但我还是喜欢遵循官方的文档说明,尽量用原生方法实现相关效果,且方方面面的都是用最新版本,也算是版主推荐规范化思路下的一个 “叛逆邪道” 吧,自己也需要解决时不时遇到的新版本兼容问题。总之希望这篇文章可以为初学者提供一个新思路,毕竟我们是学习阶段,而非生产环境开发,多学一点是一点。
相比我之前 8.x 的经验分享,这个属于新技术的学习与适配,第一次遇到新版本内容我也栽了。自行学习,寻找方案,然后解决问题,学会思路比学会方法更重要,相信后期的 10.x 、100.x 版本也会有更多新内容、新变动,大家一定要掌握解决问题的思路,死板学方法是行不通的,希望各位学习路上的初学者们不要放弃这一优美的框架,要不太可惜了!
# bootstrap
# laravel
# 自己的
# 工作流
# 这一
# 就行
# 线上
# 解决问题
# 版主
# 新版本
# 相比较
# 中能
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
移动端脚本框架Hammer.js
Laravel如何处理和验证JSON类型的数据库字段
如何快速启动建站代理加盟业务?
深圳网站制作培训,深圳哪些招聘网站比较好?
js代码实现下拉菜单【推荐】
如何用PHP快速搭建CMS系统?
如何快速查询网址的建站时间与历史轨迹?
如何在阿里云虚拟主机上快速搭建个人网站?
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Thinkphp 中 distinct 的用法解析
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
Laravel如何创建自定义Facades?(详细步骤)
linux写shell需要注意的问题(必看)
高端建站如何打造兼具美学与转化的品牌官网?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
什么是javascript作用域_全局和局部作用域有什么区别?
微信小程序 配置文件详细介绍
浅谈javascript alert和confirm的美化
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
青岛网站建设如何选择本地服务器?
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】
Linux系统命令中tree命令详解
利用vue写todolist单页应用
如何在腾讯云服务器上快速搭建个人网站?
如何在宝塔面板创建新站点?
网站制作价目表怎么做,珍爱网婚介费用多少?
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
大连网站制作公司哪家好一点,大连买房网站哪个好?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
Laravel如何使用Vite进行前端资源打包?(配置示例)
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
如何实现建站之星域名转发设置?
Linux系统运维自动化项目教程_Ansible批量管理实战
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
如何选择PHP开源工具快速搭建网站?
js实现点击每个li节点,都弹出其文本值及修改
如何生成腾讯云建站专用兑换码?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
如何快速搭建高效WAP手机网站?
如何快速上传建站程序避免常见错误?
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明

