html动态加载script

复制代码
<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>动态添加JavaScript代码</title>  
</head>  
<body>  
    <h1>Hello, World!</h1>  
  
    <button onclick="addScript()">点击添加脚本</button>  
  
    <script>  
        function addScript() {  
            // 创建一个新的script元素  
            var script = document.createElement("script");  
              
            // 设置脚本的内容  
            script.textContent = `  
                document.body.innerHTML += "<p>这是一段动态添加的文本。</p>";  
            `;  
              
            // 将脚本添加到body元素  
            document.body.appendChild(script);  
        }  
    </script>  
</body>  
</html>

当HTML文档被完全加载和解析完成时,DOMContentLoaded事件会被触发。这比load事件更早,因为在DOMContentLoaded事件触发时,样式表、图像和子框架可能还没有完全加载。

复制代码
<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>Dynamic Script Loading</title>  
</head>  
<body>  
    <script>  
        document.addEventListener("DOMContentLoaded", function() {  
            var script = document.createElement("script");  
            script.src = "path/to/your/script.js";  
            document.body.appendChild(script);  
        });  
    </script>  
</body>  
</html>

当一个资源(如脚本、图像或样式表)完成加载时,load事件被触发。这通常用于检测外部资源是否已完全加载。

复制代码
<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>Dynamic Script Loading</title>  
</head>  
<body>  
    <script>  
        window.addEventListener("load", function() {  
            var script = document.createElement("script");  
            script.src = "path/to/your/script.js";  
            document.body.appendChild(script);  
        });  
    </script>  
</body>  
</html>

使用jQuery,你可以使用$(document).ready()方法来确保在DOM加载完成后执行代码。这与DOMContentLoaded事件类似。

复制代码
<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>Dynamic Script Loading</title>  
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>  
</head>  
<body>  
    <script>  
        $(document).ready(function() {  
            var script = document.createElement("script");  
            script.src = "path/to/your/script.js";  
            document.body.appendChild(script);  
        });  
    </script>  
</body>  
</html>
相关推荐
TE-茶叶蛋8 分钟前
Web Workers 使用指南
开发语言·前端·javascript
_龙小鱼_15 分钟前
Vue Router动态路由与导航守卫实战
前端·javascript·vue.js·html5
代码搬运媛16 分钟前
Webpack 分包策略详解及实现
前端·webpack·node.js
BillKu43 分钟前
el-radio-group 与 el-dropdown 组合使用的注意事项
前端·javascript·vue.js
黑匣子~1 小时前
Electron 后台常驻服务实现(托盘 + 开机自启)
前端·javascript·electron
逍遥德1 小时前
CSS display有几种属性值
前端·css·css3
Ares-Wang1 小时前
net Core》》包与库 LibMan、NPM
前端·npm·node.js
charlee442 小时前
实现一个前端动态模块组件(Vite+原生JS)
前端·javascript·html·vite
繁依Fanyi2 小时前
用 UniApp 开发 TilePuzzle:一个由 CodeBuddy 主动驱动的拼图小游戏
前端·uni-app·编辑器·codebuddy首席试玩官
繁依Fanyi2 小时前
用 CodeBuddy 搭建「MiniGoal 小目标打卡器」:一次流畅的 UniApp 开发体验
前端·游戏·uni-app·codebuddy首席试玩官