js中load载入html页面,使用jquery的load方法加载html页面,但是html引入的js不生效
Write By Monkeyfly
以下内容均为原创,如需转载请注明出处。
前提
有一个公共的登录弹框页面需要在多个页面引用,百度后就使用了jQuery 的 load 方法。
做法:
将公共的 html 页面提取出来,放在一个独立的 HTML 文件中。
然后在需要使用的 html 页面中,使用 jQuery 的 load 方法进行引用即可。
注:提取的部分,不需要包含多余的、等标签,只需要放置你所用到的标签即可。
用法:
jQuery 中的 load 方法
jQuery.load() AJAX 函数详解
具体代码如下:
//HTML部分:
//js部分:
//当前页面的js文件
$(function(){
/*公共部分:登录弹框*/
$("#login_box").load("../../template/login/login.html");
})
//引入的公共登录页面的js文件
不想看代码的可以看图:
carriage.js 文件中的部分 html 代码如下所示
login.js 文件中的 部分 js 代码如下所示:
发现问题
注:这里以 关闭按钮 (即 .layer-close-icon 元素)为例,进行了测试和调试。
代码运行后发现:登录弹框页面中所有元素的绑定事件都没有被触发。点击关闭按钮也没有反应。
控制台调试后发现:在为 $(".layer-close-icon") 注册点击事件时,根本就没有找到该元素。【如下图所示】
在控制台查看当前的 HTML 结构,发现:此时,登录框并没有被加载进来。所以,页面元素目前还不存在,当然获取不到该元素,也就不能为它注册点击事件了。【如下图所示】
后来思考了许久,也问了一下同事,得出一个结论:这与页面中 js 文件 的加载和执行顺序有关系。
页面上的js代码是HTML页面的一部分,所以js在页面装载时的执行顺序就是其引入标签的出现顺序。
标签里面的 js 代码 或者 通过 src 引入的外部 js,都是按照其语句出现的顺序执行,而且执行过程是文档装载的一部分。
当页面中的 DOM 元素全部加载完毕后就执行jQuery 中的 $(document).ready(function(){})方法,或简写为:$(function(){})。
如果在执行 .ready() 方法之前有 js 代码存在,那么会先执行 ready()方法 之前的 js 代码,然后再执行 .ready()方法。
参考资料: 浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
解决问题
然后通过百度搜了一段时间,突然发现一个貌似可行的解决方法: jQuery 中的 $.getScript() 方法。
搜到的答案如下:
(点击查看)jquery load 加载html 但是html包含的js不生效 ,求助!!
为什么说貌似可行呢?一是没见过,二是没用过,三是感觉应该没问题。
经过测试,发现确实可行。具体代码如下图所示:
jQuery.getScript() 函数用于动态加载JS文件,并在全局作用域下执行文件中的JS代码。
请注意: 该函数是通过异步方式加载数据的。不要直接在 jQuery.getScript() 执行后直接调用该 js 文件中的变量或函数。
关于该方法的详情,请点击 jQuery.getScript() 函数详解 查看。
结束语
至此,问题就已经被解决了。
后来同事又给我提供了一个新的思路:
加载完 HTML 文件之后,使用 js 动态创建一个 script 标签,然后通过它的 src 属性,指向你所要引入的js文件的路径。
而且load方法可以使用一个回调函数作为第二个参数,所以我们可以在回调函数中动态的将 js 文件加载进来。
具体代码如下所示:【亲测可行】
$(function(){
/*公共部分:登录弹框*/
$("#login_box").load("../../template/login/login.html",function(){
var sc = document.createElement("script");
sc.src= "../../template/login/login.js";
$("body").append(sc);
});
/* $.getScript("../../template/login/login.js",function(){
// alert("载入成功!");
}); */
})
参考资料:
html中引入调用另一个公用html模板文件的方法
如何让html引用公共的头部和尾部(多个html文件公用一个header.html和footer.html)
js中load载入html页面,使用jquery的load方法加载html页面,但是html引入的js不生效相关推荐
- php jq如何刷新当前页面,使用jQuery刷新(重新加载)一次页面?
使用jQuery刷新(重新加载)一次页面? 我想知道如何使用jQuery刷新/重新加载页面(甚至特定div)一次(!)? 理想情况下,在replace()可用之后(参见onload事件)并且不会对ba ...
- ajax的get json数据格式,jQuery / 用getJSON()方法加载JSON格式数据 - 汇智网
加载JSON格式数据 jQuery的AJAX中使用getJSON()方法异步加载JSON格式数据.获取服务器中的数组,并对获取的数据进行解析,显示在页面中. 语法:$.getJSON(url,[dat ...
- JQery的lond方法加载内部页面,内部页面不加载Js
解决 办法(亲测可用):参考网址: https://blog.csdn.net/Doulvme/article/details/53835364
- layui父页面调用子页面的渲染_layUI ajax加载html页面后重新渲染的方法
相关问题同: 1.layUI使用jquery.load加载界面时,如何让layui渲染页面? 2.layUI ajax加载html页面后重新渲染 layUI ajax加载html页面后渲染,关键在将h ...
- HTML通过js的.load()方法加载页面头部和底部文件
前言: 大部分网站的头部和底部都是一样的,把公共头部和底部分离出来,使用时直接引用比重复写在每个页面好的多,对于后期的维护和二次开发,也比较友好.实现方法如下: <!DOCTYPE html&g ...
- 前端 JS 如何在一个页面中局部加载其它页面的数据
一个页面很大,可以分成多个部分,先把小部分的 jsp 写好之后,再在主页面中通过 Struts 2 标签或 ajax 请求来引入其它的 jsp 显示信息. 通过 jQuery 函数来加载其它页面的数据 ...
- JS中使用FormData上传文件、图片的方法
参考博客:http://www.cnblogs.com/xiaohuochai/p/6543019.html http://www.cnblogs.com/qcloud1001/p/6839541.h ...
- 如何加载HTML页面页面到另一个界面中
1.第一种:iframe 但是,对于个人经验来说,iframe最好不要用,不仅自适应不太好,而且对于seo优化特别不好 2.第二种:通过jQuery load 事件加载页面.比较简单,但是会刷新界面. ...
- java中如何设置浏览器宽度_[Java教程]关于JS中获取浏览器高度和宽度值的多种方法(多浏览器)_星空网...
关于JS中获取浏览器高度和宽度值的多种方法(多浏览器) 2017-08-07 0 三种浏览器获取值方法 IE中: document.body.clientWidth ==> BODY对象宽度 d ...
最新文章
- 进程、线程与应用程序域
- 数据操纵语言(DML)
- valid Palindrome -- leetcode
- SAP成都研究院CEC团队三巨头之一:M君的文章预告
- python做excel数据分析统计服_Python也能做到Excel那样,条件统计轻松解决工作需求...
- 网站前端设计,从960框架开始
- android 5.0 新功能,Android 5.0新特性有哪些?安卓5.0新功能汇总
- 镜像上传到linux失败,Docker push镜像失败解决方法
- R-CNN 最直观的理解
- (38)FPGA面试题Verilog设计计数器
- 九问国产操作系统,九大掌门人万字回应!
- VR线下体验店群雄并起,超级队长为何能靠IP突围?
- Java-static概述
- java命名不规范会怎样_java命名规范:注重细节
- 计算机硬件维修的步骤和方法,计算机硬件维护的具体方法
- matlab二维傅里叶变换ffshift,形象理解二维傅里叶变换
- css常用单位总结: px / em / rem / vw / vh / vmax / vmin
- 普及!cmnet、cmiot还傻傻分不清楚?APN设置看看这一篇就够了!!
- 银从个人理财在线计算机怎么使用,2017银行从业个人理财计算器使用方法
- 程序员中的奇葩,使用php构建魔兽世界
热门文章
- oracle vertica性能对比,测试Vertica性能
- linux如何移动数据到文件系统,怎么把数据文件从文件系统移动到asm?
- 全国计算机运用计算机绘图考试,计算机绘图期末考试题库
- 利用python 对比相似度_头条、油条商标有多像?Python检测发现相似度高达98.4%
- js代码自动排版_接口测试平台代码实现9:菜单常显
- 01初识鸿蒙_移动通讯技术的发展
- BZOJ4205卡牌配对——最大流+建图优化
- javax.xml.bind.UnmarshalException: 意外的元素 (uri:, local:xml)。所需元素为(none)
- 简单的实现登录拦截及统一异常处理(自定义异常)
- eclipse实现代码块折叠-类似于VS中的#region……#endregion