分享Laravel整合Bootstrap4的完整方案

下面由laravel教程栏目给大家介绍laravel整合bootstrap 4的完整方案 ,希望对需要的朋友有所帮助!

2018年1月23日更新: 如果你是想在laravel5.5上直接使用bootstrap 4,这应该是相对明智的,因为bootstrap 4最终版本已经发布了,那么这里有一个好消息,就是你不需要一步步执行下面的步骤了,你可以通过安装一个插件来快速使用上boostrap 4了,插件链接:laravelnews/laravel-twbs4,具体如何使用就不赘述了,按照插件文档进行就好了。 如果你是在laravel5.5之前的版本整合bootstrap 4,那么你还是需要走一遍下面的流程:

(一)安装bootstrap及相应依赖

npm install bootstrap@4.0.0-beta popper.js --save-dev

bootstrap-sasspackage.json中删除,然后再执行npm install

(二)在你的app.scss文件中引入新的bootstrap的sass文件

//替换掉之前bootstrap-sass的引入//如果你是laravel 5.5及以后的版本,这里的node_modules换成~符号@import "node_modules/bootstrap/scss/bootstrap";

(三)编译bootstrap的js文件

在这一步可能你会想直接复制一份你的bootstrap.min.js文件到public目录,然后引用,但实际上这样是不行的,因为bootstrap 4的js组件还依赖jqueryPopper.js,默认的bootstrap.min.js文件并没有编译进去。

方法一 使用bootstrap.min.js来编译

这个时候我们需要在webpack.mix.js添加这么几行:

mix.autoload({    jquery: ['$', 'window.jQuery',"jQuery","window.$","jquery","window.jquery"],        'popper.js/dist/umd/popper.js': ['Popper']});mix.js([        'node_modules/bootstrap/dist/js/bootstrap.min.js'        ],'public/js/bootstrap.min.js')

可以看到,我们通过mix.autoload()方法自动加载jqueryPopper.js,这样在下面mix.js()方法编译bootstrap.min.js文件的时候就把相应的依赖编译进去了,最后我们将编译好的文件发送到了public/js/目录下,然后在需要的地方调用即可。

方法二 使用bootstrap.bundle.min.js来编译

如果你到bootstrap的node_modules/bootstrap/dist/js/目录下,会发现还有一个bootstrap.bundle.min.js文件,这个文件里其实已经预先编译了Popper.js进去,但是没有jquery,所以刚才的webpack.mix.js文件里,我们其实也可以这样来写:

mix.autoload({    jquery: ['$', 'window.jQuery',"jQuery","window.$","jquery","window.jquery"]});mix.js([        'node_modules/bootstrap/dist/js/bootstrap.bundle.min.js'        ],'public/js/bootstrap.min.js')

最终压缩出来的文件都是一样的,如果你是用npm run dev来编译,那么第二种方法压缩出来的文件要小一点,但如果是到了生产环境,也即npm run production,那么两者的大小都是一样的。

当然,第二种方法除了少写一行,还有一个好处,就是在最开始的时候,就不需要npm install popper.js了,无可厚非了,少下载个组件而已。

AiTxt 文案助手 AiTxt 文案助手

AiTxt 利用 Ai 帮助你生成您想要的一切文案,提升你的工作效率。

AiTxt 文案助手 15 查看详情 AiTxt 文案助手

(四)加载bootstrap 4的分页视图(pagination blade)

至此,大家就可以按照bootstrap 4文档在blade视图中实际使用了,或者将已有的bootstrap 3的改成4的,因为这是bootstrap的一次相对颠覆性的升级,所以无法向下兼容,取决于你的项目大小,但一般而言将bootstrap 3的改成4是需要费一阵子功夫的。

具体的不多谈,这期间可能比较困惑的就是如何升级bootstrap 4的分页样式,方法也很多,这里提供一个最简单最快速的:

首先,找到你的resources/views/vendor/pagination目录,这是laravel默认的分页样式视图文件,如果没有执行一下php artisan vendor:publish就有了

default.blade.phpbootstrap-4.blade.phpsimple-default.blade.phpsimple-bootstrap-4.blade.php

可以看到laravel其实默认就已经为我们准备好了bootstrap 4的分页模板文件,这个时候最简单的就是改一下文件名字即可,之前的default.blade就是原来的bootstrap 3的,所以我们可以将其改成bootstrap-3.blade.php,然后将bootstrap-4.blade改成默认的default.blade,这样laravel加载分页的时候用的就是4的样式了。

固然,你也可以像laravel文档上说的,在每一次渲染分页的时候指定具体的分页视图文件,比如:

$paginator->links('vendor.pagination.bootstrap-4')

但这样太麻烦,知道即可。

以上就是分享Laravel整合Bootstrap4的完整方案的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/349038.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 21:30:53
下一篇 2025年11月5日 21:33:13

相关推荐

  • jQuery表单数据处理:确保隐藏输入值正确提交到后端

    本文旨在解决使用jQuery时隐藏输入值无法正确提交到后端(如Laravel)的问题。我们将深入探讨隐藏输入字段的正确创建与管理方法,涵盖如何在DOM中插入、设置其名称和值,以及如何将其与自定义UI交互逻辑相结合,确保表单数据完整可靠地传输。 隐藏输入字段的作用与常见问题 在Web开发中,隐藏输入字…

    2025年12月20日
    000
  • Laravel 中嵌入 YouTube 视频:优化方案与实践

    本文旨在提供一种在 Laravel Blade 模板中嵌入 YouTube 视频,并尽可能避免使用 使用 Plyr.io 嵌入 YouTube 视频 虽然完全避免使用 步骤 1:引入 Plyr.io 的 CSS 和 JavaScript 文件 首先,在你的 Blade 模板中引入 Plyr.io 的…

    2025年12月20日
    000
  • Laravel 中高效嵌入 YouTube 视频:告别 IFrame 的优化方案

    本文旨在介绍如何在 Laravel Blade 模板中高效嵌入 YouTube 视频,避免使用传统的 IFrame 标签,从而提升网页加载速度和用户体验。我们将探讨使用 Plyr.io 视频播放器库的方案,并通过示例代码演示如何在 Laravel 项目中集成和使用 Plyr.io,实现无 IFram…

    2025年12月20日
    000
  • 优化Alpine.js与Vite的集成:解决数据组件未定义问题及最佳实践

    本教程旨在解决在Laravel 10中使用Vite集成Alpine.js时遇到的“Expression not defined”错误。核心问题在于Alpine.js数据组件的注册顺序,即必须在调用Alpine.start()之前完成所有Alpine.data()的定义。文章将详细解释这一机制,提供正…

    2025年12月20日
    000
  • 优化Laravel 10与Vite中Alpine.js组件的集成与管理

    本文旨在解决在Laravel 10与Vite环境中集成Alpine.js时,自定义数据函数无法在Blade模板中正确调用的问题。核心在于Alpine.js扩展注册与启动顺序的优化,并进一步提供将Alpine组件模块化的最佳实践,以提升代码的可维护性和可扩展性,帮助开发者高效构建交互式前端应用。 理解…

    2025年12月20日
    000
  • 解决Laravel 10与Vite集成中Alpine.js数据函数未定义的问题

    在Laravel 10项目中,当开发者尝试使用Vite构建工具打包前端资产,特别是与Alpine.js结合时,可能会遇到一个常见的错误:“Alpine Expression Error: addComponent is not defined”。尽管HTML模板中的Alpine指令和JavaScri…

    2025年12月20日
    000
  • 在摩尔多瓦创建网站:成功的关键步骤

    在摩尔多瓦建立网站是企业、自由职业者和创业者拓展在线业务的关键一步。无论您需要的是个人博客、电商平台还是公司官网,都需要遵循以下几个重要步骤: 域名和主机选择: 首先,选择一个能够体现您品牌形象的域名。摩尔多瓦常用的域名后缀包括 .md 和 .com。 接下来,选择一个速度快、稳定性高的可靠主机服务…

    2025年12月19日
    000
  • 网络开发的学习路径

    开启您的网络开发之旅!这份指南涵盖了核心技术、常用框架以及学习资源,无论您是新手还是想提升技能的开发者,都能从中获益。 一、核心技能: HTMLCSSJavaScriptGit & GitHub 二、选择您的方向: 前端开发: 学习一个前端框架,例如:ReactVueAngular后端开发:…

    2025年12月19日
    000
  • ENV文件要考虑的OST重要事项列表

    大型项目开发中,.env 文件的管理至关重要。本文总结了六个最佳实践,帮助您在开发和生产环境中安全有效地使用 .env 文件。 1. .env 文件权限设置: 大多数 Web 应用(如 React.js、Laravel 或 Node.js)都使用 .env 文件存储环境变量。 Linux 系统默认隐…

    2025年12月19日
    000
  • 最佳 JavaScript 框架 Nextjs 与 Laravel、新的开发人员工具等

    JavaScript 开发者们,大家好! 欢迎阅读本周 JavaScript 最新动态! 2025 年伊始,令人振奋的趋势正在涌现,包括技术栈的演变、Laravel 与 Next.js 的竞争,以及一些能提升开发效率的便捷新工具。 JavaScript 技术栈的新变化 2025 年,在 AI 辅助开…

    2025年12月19日
    000
  • Google Project IDX、Material UI 的新 React 组件库等等

    JavaScript 开发者们,大家好! 本周的JavaScript 新闻速递来啦! 即使假期来临,JavaScript的世界依旧精彩纷呈。无论您是专注性能优化、深入研究现代框架,还是探索新型数据库,我们都为您准备了重磅更新、实用工具和版本升级,助您提升开发效率。 Google Project ID…

    2025年12月19日
    000
  • 使用 Laravel、Inertiajs v 和 Vue 3 实现无限滚动

    在这篇综合指南中,我们将探索如何使用 inertia.js v2.0 和 vue 3 在 laravel 应用程序中实现无限滚动。我们将介绍前端和后端实现,特别注意处理整页刷新并保持滚动位置。 目录 了解组件前端实现后端实现现实示例:带有类别的博客文章最佳实践和注意事项 了解组件 无限滚动的实现依赖…

    2025年12月19日
    000
  • 进入后端世界的新 Web 开发人员必须了解的技巧

    过渡到后端开发对于 Web 开发人员来说既令人兴奋又充满挑战。前端专注于用户界面和体验,而后端开发则处理为 Web 应用程序提供支持的幕后逻辑、数据库和服务器端进程。如果您是刚进入后端世界的新开发人员,这里有十个基本技巧可以帮助您导航和发展。 1。了解后端的作用后端是 Web 应用程序的基础。它处理…

    2025年12月19日
    000
  • Lithe 内部:PHP 框架如何改变游戏规则

    近年来,使用 PHP 进行 Web 开发取得了令人瞩目的发展,极简框架也变得越来越流行。其中,Lithe 作为轻量级、敏捷且功能强大的解决方案脱颖而出,专为寻求灵活性和性能的开发人员而设计。但 Lithe 到底是如何改变 PHP 开发的游戏规则的呢?让我们深入了解一下为什么这个微框架越来越受到关注。…

    2025年12月19日
    000
  • 我作为全栈开发者的旅程:从 Laravel 到 Nextjs

    作为一名全栈开发人员,我踏上了一段激动人心的旅程,这让我能够探索各种技术、框架和开发实践。在本文中,我想分享我使用 Laravel 进行后端开发和使用 Next.js 进行前端解决方案的经验,以及我在构建创新应用程序时如何在它们之间进行转换。 Laravel API 冒险我的旅程始于 Laravel…

    2025年12月19日
    000
  • 实时交付披萨应用程序

    是一个小型 Laravel CRUD 项目。本项目采用了服务模式。但这个项目的主要特点是高级功能。这些是 – 活动功能。实时通知系统。数据库通知系统。邮件功能。数据库备份功能。安排命令功能。 现在的竞争非常激烈。如果您的项目组合中有一个具有这些高级功能的项目,那么您将会领先一些。 最后,我将尝试展示…

    2025年12月19日
    000
  • Express NextJS NestJS 初学者速查表

    简介 我最近必须学习 nestjs,为一个用它编写的项目做好准备。请注意,不是 nextjs,而是 nestjs。和你们中的一些人一样,我听说过它,但从未有机会实际使用它。它已经流行了一段时间了,今年早些时候赶上了 nodejs 后端开发的鼻祖——expressjs。这是他们的官方推文: <i…

    好文分享 2025年12月19日
    000
  • 使用 Secrets Loader 轻松管理 Laravel 和 JS 项目

    跨各种环境管理 api 密钥、令牌和凭证等敏感数据可能非常棘手,尤其是在开发和部署应用程序时。确保秘密在需要时安全地存储和获取,而不是将它们硬编码到版本控制中,对于维护安全性至关重要。 这就是我创建 secrets loader 的原因,这是一个 bash 脚本,可以动态地将 aws ssm 和 c…

    2025年12月19日
    000
  • 当超级管理员因错误而不允许用户登录时会发生什么

    想象一下,您是网络应用程序的用户,兴奋地导航到登录页面以访问您的帐户,然后输入凭据,单击闪亮的“登录”按钮,然后满怀期待地等待。但可惜的是,您的个性化仪表板并没有迎接您,而是出现了一条不祥的错误消息:“抱歉,由于系统错误,站点管理员已暂时禁用用户登录。”当您感到沮丧时,您可能想知道是什么导致了这种不…

    2025年12月19日
    000
  • 在 Laravel 项目中使用 SCSS 和 TailwindCSS 代码示例

    在编码领域,人们经常意识到什么有效,什么无效,以及尽管是新事物,但什么可以带来明确的改变。在这个小教程中,我将向您展示将 scss tailwindcss 一起用于无数 web 应用程序的最简单的事情。这个强大的组合可以显着增强您的 web 开发工作流程并创建更易于维护的样式表。 所以在开始之前先做…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信