不使用script导入js文件的几种方法
程序员文章站
2022-03-29 19:11:26
...
方法一:原生
adc.js内容如下:
var hello = "H9";
html.html
<script> var s = document.createElement("script"); s.src = "abc.js"; document.head.appendChild(s); s.addEventListener("load",function(){ // 等待s的load事件加载完响应,防止未加载完就调用出错 console.log(hello); }) setTimeout(function(){//或者使用定时器保证其载入完后调用(不安全,不如监听事件好) console.log(hello); },1000); // $.getScript("abc.js"); </script>
方法二:jquery.js
$.getScript("abc.js",function(){ alert("heheheh"); console.log(hello); });
<script type="text/javascript" src="../jquery.js"></script> <script type="text/javascript"> $(function() { $('#loadButton').click(function(){ $.getScript('new.js',function(){ newFun('"Checking new script"');//这个函数是在new.js里面的,当点击click后运行这个函数 }); }); }); </script> </head> <body> <button type="button" id="loadButton">Load</button>
方法三:require.js
require.js分享2.1.1版本,注意是针对大项目使用,一边情况下使用jquery即可。
index.html
<!--设置入口文件main 可以省略js-->
<script data-main="main" src="require.js"></script>
main.js
console.log("你好世界"); require(["js1","js2","js3"],function () { // 是异步加载导入。js后缀可以省略 console.log("你们加载完了么?"); var total = num1+num2+num3; console.log(total); hello1(); hello2(); hello3(); })
使用requireJs可以很方便的导入js文件,但是要注意js文件中变量名方法名冲突的问题。 产生原因:浏览器js文件共用全局作用域,作用域中变量名方法名可能被覆盖
推荐阅读
-
在vue.js中使用JSZip实现在前端解压文件的方法
-
使用JS在浏览器中判断当前网络连接状态的几种方法
-
ae怎么导入并使用ffx预设文件? ae预设ffx的使用方法
-
使用jquery动态加载js文件的方法教程
-
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
-
php使用gzip压缩传输js和css文件的方法
-
使用PDF.JS插件在HTML中预览PDF文件的方法
-
【C#常用方法】2.DataTable(或DataSet)与Excel文件之间的导出与导入(使用NPOI)
-
使用jQuery动态加载js脚本文件的方法
-
使用grunt合并压缩js和css文件的方法