Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

强制动态加载的 JavaScript 脚本按顺序执行

Posted on 2025-11-05

herman-1683556668-0.png

当你在 HTML 文档中动态添加多个<script>标签时,这些脚本是异步加载的。因此,如果第二个脚本依赖于前面的脚本,就可能无法正常工作。我尝试在 `<script>` 标签上使用defer ,但完全没有效果。

我的方法逐个添加<script>标签,并使用load事件将下一个脚本 URL 添加到列表中。我的解决方案还允许您向最后一个脚本节点添加data-{key}={value}属性,以便您可以使用currentScript属性进行设置。

注意:我将脚本标签添加到了<body>标签的末尾。如果您希望将脚本添加到其他位置,可以编辑我的函数的第一行。

用法:

常量 脚本 = [     
    'https://example.org/dependency1.js '     
    'https://example.org/dependency2.js '     
    'https://example.org/generate-table-of-contents.js'     
];     
常量 数据属性 = {     
    标题: 页面内容:     
    按钮文本: “生成目录”     
};     
load_scripts_in_order ( scripts , 数据属性)     

按顺序加载脚本:

 /**   
* 创建一个 `<script>` 节点,设置 onload 事件以执行列表中的下一个脚本。   
*   
* @param scripts_array 一个包含一个或多个条目的 JavaScript URL 数组   
* @param final_script_settings key=>value 数组,包含要仅应用于数组中最后一个节点的 `data-{key}={value}` 设置项   
*/     
功能 load_scripts_in_order ( scripts_array , final_script_settings ){     
    常量 身体 = document.querySelector ( ' body' ) ;     
    常量 脚本 = document.createElement ( 'script ' ) ;     
    script.setAttribute ( ' type ' , "text/javascript" );     
    script.setAttribute ( ' src ' , scripts_array [ 0 ]);     
    如果 ( scripts_array .长度 > 1 ){     
        script.addEventListener ( ' load ' ,     
            load_scripts_in_order.bind ( this ,​​ scripts_array.slice ( 1 ) ,​     
                final_script_settings     
            )     
        );     
   
    }     
    如果 ( scripts_array .长度 == 1 ){     
        为了 (常量) 环境 在 final_script_settings ){     
            script.setAttribute ( ' data- ' +设置, final_script_settings [设置]);     
        }     
    }     
   
    body.appendChild ( script ) ;​     
}     

原文: https://reedybear.bearblog.dev/force-dynamically-loaded-javascript-scripts-to-execute-in-order/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Anil Dash
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Big Technology
  • Bits about Money
  • Brandon Skerritt
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • eighty twenty
  • Elad Gil
  • Ellie Huxtable
  • Ethan Dalool
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • HeardThat Blog
  • Henrique Dias
  • Herman Martinus
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Li Haoyi
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Maggie Appleton
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mind Matters
  • Mostly metrics
  • Naval Ravikant
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Rohit Patel
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Steph Ango
  • Stephen Wolfram
  • Steve Blank
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • Wes Kao
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme