@endpush @push(\\'scripts\\') @endpush

在这种情况下,script1.js 将在 script2.js 之前加载,因为 @push 按照声明的顺序将内容添加到堆栈中。

  1. 在 Partials 和组件中使用 @push:@push 也可以在 Blade 部分(例如 @include)或 Blade 组件中使用。这对于将特定于视图的脚本或样式直接包含在可重用组件中非常有用,从而可以轻松管理依赖项。
      
@push(\\'scripts\\') @vite(\\'resources/js/partial-specific.js\\') @endpush

当此部分包含在视图中时,partial-specific.js 将被添加到布局文件中的脚本堆栈中。

  1. 使用@prepend控制顺序:如果特定脚本需要在同一堆栈中的其他脚本之前加载,则可以使用@prepend而不是@push。 @prepend 将内容放置在堆栈的开头,从而可以更好地控制加载顺序。
   @prepend(\\'scripts\\')          @endprepend   @push(\\'scripts\\')          @endpush

这里,ritical.js 将在 non_ritic.js 之前加载,无论它们在 Blade 文件中的位置如何。

要点


4.替代方案:在布局中使用内联条件语句

如果您需要更好地控制何时包含 JavaScript,Laravel 的条件语句允许直接在布局中使用基于路由或变量的逻辑。

根据路线有条件地包含

您可以直接在布局中使用路由检查来包含基于当前路由的 JavaScript:

@if (request()->routeIs(\\'some.route.name\\'))    @vite(\\'resources/js/custom.js\\')@endif

基于变量有条件包含

要根据变量有条件地加载脚本,您可以在控制器或子视图中设置一个标志,然后在布局中检查它:

  1. 在你的控制器中
   return view(\\'your.view\\', [\\'loadCustomJS\\' => true]);
  1. 在布局中
   @if (!empty($loadCustomJS))       @vite(\\'resources/js/custom.js\\')   @endif

这种方法允许您根据特定变量或路由控制 JavaScript 加载,为自定义页面设置提供灵活性。


概括

以下是所讨论方法的快速概述:

这些选项允许您精确控制 JavaScript 加载,使您的 Laravel 11 项目高效且可维护。

","image":"http://www.luping.net/uploads/20241111/17313105816731b3f508523.jpg","datePublished":"2024-11-11T16:46:05+08:00","dateModified":"2024-11-11T16:46:05+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在 Laravel 中包含 JavaScript 適用於所有場景的逐步指南

如何在 Laravel 中包含 JavaScript 適用於所有場景的逐步指南

發佈於2024-11-11
瀏覽:542

How to Include JavaScript in Laravel  A Step-by-Step Guide for All Scenarios

如何在 Laravel 11 中包含 JavaScript:适用于所有场景的分步指南

在 Laravel 11 中,由于默认的资源捆绑器 Vite,向项目添加 JavaScript 变得轻而易举。以下是如何为各种场景设置 JavaScript,从全局包含到特定视图中的条件加载。


1. 在所有文件中包含 JavaScript

在许多情况下,您可能希望在 Laravel 应用程序中全局包含 JavaScript。以下是如何组织和捆绑 JavaScript 以实现普遍包容。

第 1 步:放置 JavaScript 文件

  1. 位置:将JavaScript文件存放在resources/js目录中。例如,如果您的文件名为 custom.js,请将其另存为 resources/js/custom.js.
  2. 组织:对于包含多个JavaScript文件的复杂项目,可以将它们组织在resources/js的子目录中,例如resources/js/modules/custom.js。

第2步:使用Vite编译JavaScript

Laravel 11 使用 Vite 来管理资产。要将其配置为捆绑您的 JavaScript:

  1. 包含在app.js中:打开resources/js/app.js并导入您的自定义文件:
   import './custom.js';
  1. 在视图中直接导入:或者,如果您只想在某些视图中使用 JavaScript,您可以在 Blade 模板中使用 @vite 指令:
   @vite('resources/js/custom.js')

第三步:配置vite.config.js

确保 vite.config.js 设置为正确处理 @vite 导入。默认情况下,它应该看起来像这样:

import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';

export default defineConfig({
    plugins: [
        laravel({
            input: ['resources/js/app.js'],
            refresh: true,
        }),
    ],
});

第四步:运行Vite

使用Vite编译您的资产:

  • 对于开发:运行 npm run dev
  • 对于生产:运行 npm run build

第 5 步:在 Blade 模板中加载 JavaScript

要在模板中包含 JavaScript 文件,请使用 @vite 指令:



    My Laravel App
    @vite('resources/js/app.js')


    


概括

  • JavaScript 文件存储在resources/js 中。
  • 在 app.js 中导入以进行全局包含,或根据需要直接包含在 Blade 模板中。
  • 使用Vite编译资产。
  • 在Blade模板中使用@vite加载JavaScript。

通过此设置,JavaScript 将在 Laravel 11 项目中在整个站点范围内可用。


2. 了解刀片渲染顺序

当有条件地在特定视图中包含 JavaScript 时,了解 Blade 模板的渲染顺序至关重要。

在 Laravel 中,首先处理布局,然后是单个视图和局部视图。渲染过程如下:

  1. 首先渲染布局,并为内容注入创建占位符(@yield 和 @section)。
  2. 接下来处理子视图或部分视图,并将其内容插入到布局占位符中。

由于这个顺序,如果您想根据子视图内容有条件地在布局中添加 JavaScript 文件,标准变量检查将不起作用。您需要使用 Blade 的 @stack@push 指令来更灵活地处理特定于页面的 JavaScript。


3. 使用 Stack 和 Push 有条件地将 JavaScript 包含在特定视图中

为了将 JavaScript 添加到特定视图,Laravel 的 @stack 和 @push 指令提供了一个有效的解决方案,允许您有条件地在布局中包含脚本。

第 1 步:在布局中定义堆栈

在布局中,为特定于页面的脚本创建堆栈:



    My Laravel App
    @vite('resources/js/app.js')
    @stack('scripts') 


    @yield('content')


第 2 步:从子视图推送脚本

在需要JavaScript的特定Blade文件中,推送到脚本堆栈:

@extends('layout')

@section('content')
    
@endsection

@push('scripts')
    @vite('resources/js/custom.js')
@endpush

通过此设置,仅在加载特定视图时才会包含 custom.js。此方法提供了一个与 Laravel 的渲染顺序配合使用的干净解决方案,确保根据需要有条件地包含 JavaScript 文件。


在哪里声明@push?

@push 语句在 Blade 视图中的放置主要关系到可读性和执行顺序。以下是如何有效使用@push:

  1. 视图中的放置:虽然您可以将 @push 放置在 Blade 视图中的任何位置,但最佳实践是将其放置在文件末尾,通常位于 @section 内容之后。这使得脚本相关的代码与主要内容分开,提高了可读性和可维护性。
   @extends('layout')

   @section('content')
       
   @endsection

   @push('scripts')
       @vite('resources/js/custom.js')
   @endpush
  1. 多个@push语句的顺序:如果同一个堆栈有多个@push声明(例如@push('scripts')),它们将按照它们在视图中出现的顺序附加。例如:
   @push('scripts')
       
   @endpush

   @push('scripts')
       
   @endpush

在这种情况下,script1.js 将在 script2.js 之前加载,因为 @push 按照声明的顺序将内容添加到堆栈中。

  1. 在 Partials 和组件中使用 @push:@push 也可以在 Blade 部分(例如 @include)或 Blade 组件中使用。这对于将特定于视图的脚本或样式直接包含在可重用组件中非常有用,从而可以轻松管理依赖项。
   
   
@push('scripts') @vite('resources/js/partial-specific.js') @endpush

当此部分包含在视图中时,partial-specific.js 将被添加到布局文件中的脚本堆栈中。

  1. 使用@prepend控制顺序:如果特定脚本需要在同一堆栈中的其他脚本之前加载,则可以使用@prepend而不是@push。 @prepend 将内容放置在堆栈的开头,从而可以更好地控制加载顺序。
   @prepend('scripts')
       
   @endprepend

   @push('scripts')
       
   @endpush

这里,ritical.js 将在 non_ritic.js 之前加载,无论它们在 Blade 文件中的位置如何。

要点

  • 将 @push 放在视图的末尾以提高清晰度和可维护性。
  • 顺序由视图中的位置决定,较早的@push语句首先加载。
  • @push 在部分和组件中工作,可以轻松包含特定于视图的依赖项。
  • 对于需要在同一堆栈中首先加载的脚本使用@prepend。

4.替代方案:在布局中使用内联条件语句

如果您需要更好地控制何时包含 JavaScript,Laravel 的条件语句允许直接在布局中使用基于路由或变量的逻辑。

根据路线有条件地包含

您可以直接在布局中使用路由检查来包含基于当前路由的 JavaScript:

@if (request()->routeIs('some.route.name'))
    @vite('resources/js/custom.js')
@endif

基于变量有条件包含

要根据变量有条件地加载脚本,您可以在控制器或子视图中设置一个标志,然后在布局中检查它:

  1. 在你的控制器中
   return view('your.view', ['loadCustomJS' => true]);
  1. 在布局中
   @if (!empty($loadCustomJS))
       @vite('resources/js/custom.js')
   @endif

这种方法允许您根据特定变量或路由控制 JavaScript 加载,为自定义页面设置提供灵活性。


概括

以下是所讨论方法的快速概述:

  • 全局包含:将 JavaScript 放入 app.js 中并使用 @vite 将其全局包含。
  • Stack 和 Push 的条件包含:使用 @stack 和 @push 指令进行灵活、模块化的脚本处理,确保脚本仅加载到需要的视图中。
  • 布局中的条件语句:使用基于路由的检查或控制器变量有条件地直接在布局中加载JavaScript。

这些选项允许您精确控制 JavaScript 加载,使您的 Laravel 11 项目高效且可维护。

版本聲明 本文轉載於:https://dev.to/websilvercraft/how-to-include-js-files-in-laravel-templates-49e6?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 您如何在Laravel Blade模板中定義變量?
    您如何在Laravel Blade模板中定義變量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配變量對於存儲以後使用的數據至關重要。在使用“ {{}}”分配變量的同時,它可能並不總是最優雅的解決方案。 幸運的是,Blade通過@php Directive提供了更優雅的方法: $ old_section =...
    程式設計 發佈於2025-07-20
  • \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    答案: 在大多數現代編譯器中,while(1)和(1)和(;;)之間沒有性能差異。編譯器: perl: 1 輸入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    程式設計 發佈於2025-07-20
  • 在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8表中將latin1字符轉換為utf8 ,您遇到了一個問題,其中含義的字符(例如,“jáuòiñe”)在utf8 table tabled tablesset中被extect(例如,“致電。The recommended approach to correct the data is t...
    程式設計 發佈於2025-07-20
  • Android如何向PHP服務器發送POST數據?
    Android如何向PHP服務器發送POST數據?
    在android apache httpclient(已棄用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    程式設計 發佈於2025-07-20
  • 如何處理PHP文件系統功能中的UTF-8文件名?
    如何處理PHP文件系統功能中的UTF-8文件名?
    在PHP的Filesystem functions中處理UTF-8 FileNames 在使用PHP的MKDIR函數中含有UTF-8字符的文件很多flusf-8字符時,您可能會在Windows Explorer中遇到comploreer grounder grounder grounder gro...
    程式設計 發佈於2025-07-20
  • 如何從PHP中的數組中提取隨機元素?
    如何從PHP中的數組中提取隨機元素?
    從陣列中的隨機選擇,可以輕鬆從數組中獲取隨機項目。考慮以下數組:; 從此數組中檢索一個隨機項目,利用array_rand( array_rand()函數從數組返回一個隨機鍵。通過將$項目數組索引使用此鍵,我們可以從數組中訪問一個隨機元素。這種方法為選擇隨機項目提供了一種直接且可靠的方法。
    程式設計 發佈於2025-07-20
  • 查找當前執行JavaScript的腳本元素方法
    查找當前執行JavaScript的腳本元素方法
    如何引用當前執行腳本的腳本元素在某些方案中理解問題在某些方案中,開發人員可能需要將其他腳本動態加載其他腳本。但是,如果Head Element尚未完全渲染,則使用document.getElementsbytagname('head')[0] .appendChild(v)的常規方...
    程式設計 發佈於2025-07-20
  • Spark DataFrame添加常量列的妙招
    Spark DataFrame添加常量列的妙招
    在Spark Dataframe ,將常數列添加到Spark DataFrame,該列具有適用於所有行的任意值的Spark DataFrame,可以通過多種方式實現。使用文字值(SPARK 1.3)在嘗試提供直接值時,用於此問題時,旨在為此目的的column方法可能會導致錯誤。 df.withCo...
    程式設計 發佈於2025-07-20
  • Python中何時用"try"而非"if"檢測變量值?
    Python中何時用"try"而非"if"檢測變量值?
    使用“ try“ vs.” if”來測試python 在python中的變量值,在某些情況下,您可能需要在處理之前檢查變量是否具有值。在使用“如果”或“ try”構建體之間決定。 “ if” constructs result = function() 如果結果: 對於結果: ...
    程式設計 發佈於2025-07-20
  • 用戶本地時間格式及時區偏移顯示指南
    用戶本地時間格式及時區偏移顯示指南
    在用戶的語言環境格式中顯示日期/時間,並使用時間偏移在向最終用戶展示日期和時間時,以其localzone and格式顯示它們至關重要。這確保了不同地理位置的清晰度和無縫用戶體驗。以下是使用JavaScript實現此目的的方法。 方法:推薦方法是處理客戶端的Javascript中的日期/時間格式化和...
    程式設計 發佈於2025-07-20
  • 如何避免Go語言切片時的內存洩漏?
    如何避免Go語言切片時的內存洩漏?
    ,a [j:] ...雖然通常有效,但如果使用指針,可能會導致內存洩漏。這是因為原始的備份陣列保持完整,這意味著新切片外部指針引用的任何對象仍然可能佔據內存。 copy(a [i:] 對於k,n:= len(a)-j i,len(a); k
    程式設計 發佈於2025-07-20
  • Java為何無法創建泛型數組?
    Java為何無法創建泛型數組?
    通用陣列創建錯誤 arrayList [2]; JAVA報告了“通用數組創建”錯誤。為什麼不允許這樣做? 答案:Create an Auxiliary Class:public static ArrayList<myObject>[] a = new ArrayList<my...
    程式設計 發佈於2025-07-20
  • 為什麼不使用CSS`content'屬性顯示圖像?
    為什麼不使用CSS`content'屬性顯示圖像?
    在Firefox extemers屬性為某些圖像很大,&& && && &&華倍華倍[華氏華倍華氏度]很少見,卻是某些瀏覽屬性很少,尤其是特定於Firefox的某些瀏覽器未能在使用內容屬性引用時未能顯示圖像的情況。這可以在提供的CSS類中看到:。 googlepic { 內容:url(&...
    程式設計 發佈於2025-07-20
  • 如何使用PHP將斑點(圖像)正確插入MySQL?
    如何使用PHP將斑點(圖像)正確插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call fil...
    程式設計 發佈於2025-07-20
  • 為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    網格超過身體,用100%grid-template-columns 為什麼在grid-template-colms中具有100%的顯示器,當位置設置為設置的位置時,grid-template-colly修復了? 問題: 考慮以下CSS和html: class =“ snippet-code”> ...
    程式設計 發佈於2025-07-20

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3