iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > html >怎么理解JavaScript事件加载
  • 229
分享到

怎么理解JavaScript事件加载

2024-04-02 19:04:59 229人浏览 安东尼
摘要

这篇文章主要介绍“怎么理解javascript事件加载”,在日常操作中,相信很多人在怎么理解JavaScript事件加载问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解

这篇文章主要介绍“怎么理解javascript事件加载”,在日常操作中,相信很多人在怎么理解JavaScript事件加载问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解JavaScript事件加载”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

JavaScript事件加载本身并不是什么复杂的功能,通常来说,window.onload就够用了。如果想加载多个事件,我们可以采取以下方式:

window.onload = function(){  func1();  func2();  func3();  //更多加载事件………………  }

但如果由于某种特殊需要,我们不能合在一起写吗?如当前区域是面向管理员,后台生成页面时只有当用户是管理员,页面才生成这部分,而这部分也用到一些特殊的脚本,上面的方法就歇菜了!

JavaScript事件加载:前台与后台的尴尬

//后台代码  < script type="text/javascript">  window.onload = function(){  func1();  func2();  //加载普通用户用到的脚本……  }  < /script>  < %# 以下脚本是为管理员准备的 %>  < % if @user.role == "manager"   %>  window.onload = function(){  func1();  func2();  //加载机密脚本……  }  < % end %>

这种情况生成出来的页面拥有两个window.onload代码块,很显然,第二个覆盖掉***个。这时,轮到loadEvent函数出场了。

var loadEvent = function(fn) {  var oldonload = window.onload;  if (typeof window.onload != 'function') {  window.onload = fn;  }else {  window.onload = function() {  oldonload();  fn();  }  }  }

它非常***地解决了互相覆盖的问题,用法如下:

loadEvent(func1);  loadEvent(func2);  loadEvent(func3);  //更多加载事件

但现实的问题总是如此出奇不意,也如此刁钻邪门。最近我想把所有的函数放到一个闭包中,以免除命名冲突之苦,比如那个有名的$的DOM选择器。Jquery,Prototype,mootool都用它做选择器的名字,共存成了个严重的问题。

(function(){  if(!window.js){  window['JS'] = {}  }  var onReady = function(fn){  var oldonload = window.onload;  if (typeof window.onload != 'function') {  window.onload = fn;  }else {  window.onload = function() {  oldonload();  fn();  }  }  }  JS.onReady = onReady;  var $ = function(id){  return document.getElementById(id);  }  JS.$ = $;  })()

报错,说找不到节点。为什么找不到呢?因为我们在调用它的时候,DOM树还没有建立起来!不会吧,网页是如此完整地显示我们眼前了。这与闭包的运作有关,当JS引擎解析到闭包的***一个“}”,就把里面的东西到一个密封的环境中,JS继续向下执行,就修正不了闭包中的window的属性了。window有一个出名的属性,叫做document,它引用着整个DOM树(当然还有其他操作)。DOM树是一个复杂的键值对,当JS不断向下解析时,就不断往document添加相应的节点。但当它塞进闭包后,里面的时间就静止了,因此它还停留在解析head的阶段,document是残缺的,想获取body中的节点,当然是返回null了。于是问题的关键是如何让闭包内的document重新继续向下解析。 方法有两个,一个是利用侦听器(addEventListener与attachEvent),一个是利用基于时间轴的setTimeout与setInterval。

(function(){  if(!window.JS){  window['JS'] = {}  }  var addEvent = function( obj, type, fn ) {  if (obj.addEventListener)  obj.addEventListener( type, fn, false );  else if (obj.attachEvent) {  obj["e"+type+fn] = fn;  obj.attachEvent( "on"+type, function() {  obj["e"+type+fn]();  } );  }  };  var onReady = function(loadEvent,waitForImages) {  if(waitForImages) {  return addEvent(window, 'load', loadEvent);  }  }  JS.onReady = onReady;  var $ = function(id){  return document.getElementById(id);  }  JS.$ = $;  })()

OK,没问题。上面的onReady函数有一个可选参数,判断图片是否加载完毕。我们知道JS引擎会在完成DOM树后才开始处理图片与音频等东西,但如果我们的页面严重依赖于脚本布局呢?!我们想尽快让页面呈现出大体形态,这就用到domReady了。我们在原基础上改进它。

(function(){  if(!window.JS){  window['JS'] = {}  }  var addEvent = function( obj, type, fn ) {  if (obj.addEventListener)  obj.addEventListener( type, fn, false );  else if (obj.attachEvent) {  obj["e"+type+fn] = fn;  obj.attachEvent( "on"+type, function() {  obj["e"+type+fn]();  } );  }  };  var onReady = function(loadEvent,waitForImages) {  if(waitForImages) {  return addEvent(window, 'load', loadEvent);  }  var init = function() {  if (arguments.callee.done) return;  arguments.callee.done = true;  loadEvent.apply(document,arguments);  };  if(!+"\v1"){  (function(){  try {  document.documentElement.doScroll("left");  } catch(e) {  setTimeout( arguments.callee, 0 );  return;  }  init();  })();  }else{  document.addEventListener( "DOMContentLoaded", function(){  document.removeEventListener( "DOMContentLoaded", arguments.callee, false );  init();  }, false );  }  return true;  }  JS.onReady = onReady;  var $ = function(id){  return document.getElementById(id);  }  JS.$ = $;  })()

dom标准浏览器用DOMContentLoaded,这是非常正现的W3C论DOM方法,与FF的DOMMouseScroll 不一样,基本上所有非IE内核的浏览器***版都支持它了。IE下我们可以通过侦听document. documentElement. doScroll()来判断DOM树是否完成,原理是IE下只有当DOM树构建完成后才能doScroll。但它还不是尽善尽美,它在IE下无法判定iframe的内容是否加载完毕。我们继续改进它。

(function(){  if(!window.JS){  window['JS'] = {}  }  var addEvent = function( obj, type, fn ) {  if (obj.addEventListener)  obj.addEventListener( type, fn, false );  else if (obj.attachEvent) {  obj["e"+type+fn] = fn;  obj.attachEvent( "on"+type, function() {  obj["e"+type+fn]();  } );  }  };  var onReady = function(loadEvent,waitForImages) {  if(waitForImages) {  return addEvent(window, 'load', loadEvent);  }  var init = function() {  if (arguments.callee.done) return;  arguments.callee.done = true;  loadEvent.apply(document,arguments);  };  if(!+"\v1"){  if(window.self == window.top){  (function(){  try {  document.documentElement.doScroll("left");  } catch(e) {  setTimeout( arguments.callee, 0 );  return;  }  init();  })();  }else{  document.attachEvent("onreadystatechange", function(){  if ( document.readyState === "complete" ) {  document.detachEvent( "onreadystatechange", arguments.callee );  init();  }  });  }  }else{  document.addEventListener( "DOMContentLoaded", function(){  document.removeEventListener( "DOMContentLoaded", arguments.callee, false );  init();  }, false );  }  return true;  }  JS.onReady = onReady;  var $ = function(id){  return document.getElementById(id);  }  JS.$ = $;  })()

我们简直是在重新实现jquery的$(document).ready(function(){ })!它功能非常强悍,配合利用闭包做成的命名空间,基本刀枪不入。而且它就只污染一个全局变量“JS”,可以与YUI媲美了(笑)。不过对于一般应用来说,我们用不着做到如此面面俱到。假如我们不需要对图片进行处理,页面也没有iframe,我们可以搞下面这个微缩版出来。

(function(){  if(!window.JS){  window['JS'] = {}  }  var onReady = function(loadEvent) {  if(!+"\v1"){  (function(){  try {  document.documentElement.doScroll("left");  } catch(e) {  setTimeout( arguments.callee, 0 );  return;  }  loadEvent();  })();  }else{  document.addEventListener( "DOMContentLoaded", loadEvent, false );  }  }  JS.onReady = onReady;  var $ = function(id){  return document.getElementById(id);  }  JS.$ = $;  })()

到此,关于“怎么理解JavaScript事件加载”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么理解JavaScript事件加载

本文链接: https://www.lsjlt.com/news/86818.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么理解JavaScript事件加载
    这篇文章主要介绍“怎么理解JavaScript事件加载”,在日常操作中,相信很多人在怎么理解JavaScript事件加载问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解...
    99+
    2024-04-02
  • JavaScript之window页面加载事件怎么实现
    这篇文章主要介绍了JavaScript之window页面加载事件怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript之window页面加载事件怎么实现文章...
    99+
    2024-04-02
  • JavaScript事件该怎么理解
    JavaScript事件该怎么理解,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。JavaScript事件     HTM...
    99+
    2024-04-02
  • javascript怎么添加事件和删除事件
    这篇文章主要讲解了“javascript怎么添加事件和删除事件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript怎么添加事件和删除事件”吧!...
    99+
    2024-04-02
  • 怎么在Javascript中添加事件
    怎么在Javascript中添加事件?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.添加到元素事件属性上<!DOCTYPE html><html&...
    99+
    2023-06-14
  • JavaScript中怎么利用DOM添加事件
    这期内容当中小编将会给大家带来有关JavaScript中怎么利用DOM添加事件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。JavaScript DOM添加事件这是我在给...
    99+
    2024-04-02
  • JavaScript懒加载与预加载原理与实现详解
    目录1、懒加载1.1、什么是懒加载1.2、为什么要使用懒加载1.3、懒加载的优点1.4、懒加载的原理1.5、懒加载的实现步骤1.6、懒加载的实现方式2、预加载2.1、什么是预加载2....
    99+
    2024-04-02
  • JavaScript怎么处理事件冒泡
    本篇内容介绍了“JavaScript怎么处理事件冒泡”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • javascript怎么解除绑定事件
    小编给大家分享一下javascript怎么解除绑定事件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!方法:1、使用“对象名.onclick=null”语句;2、使...
    99+
    2023-06-14
  • JavaScript懒加载详解
    目录懒加载CSS样式:HTML部分:script部分 :总结懒加载 顾名思义比较懒,不想全部加载出来,当用户什么时候想看我在加载后面的东西 概括:懒加载其实就是延时加载,即当对象需要...
    99+
    2024-04-02
  • JavaScript中怎么实现事件代理
    这期内容当中小编将会给大家带来有关JavaScript中怎么实现事件代理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。JavaScript事件代理则是一种简单的技巧,通过...
    99+
    2024-04-02
  • 深入理解JavaScript事件机制
    目录如何实现一个事件的发布订阅介绍下事件循环宏任务和微任务的区别如何实现一个事件的发布订阅 可以通过以下步骤实现 JavaScript 中的发布-订阅模式: 创建一个事件管理器对象。...
    99+
    2023-05-17
    JavaScript事件机制 JS事件机制
  • 如何理解javascript事件委托
    这篇文章主要介绍“如何理解javascript事件委托”,在日常操作中,相信很多人在如何理解javascript事件委托问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解...
    99+
    2024-04-02
  • 怎么理解类加载机制
    本篇内容主要讲解“怎么理解类加载机制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解类加载机制”吧!我们写的类,在编译完成后,究竟是怎么加载进虚拟机的虚拟...
    99+
    2024-04-02
  • 什么是JavaScript事件处理
    这篇文章主要介绍“什么是JavaScript事件处理”,在日常操作中,相信很多人在什么是JavaScript事件处理问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”什么是Jav...
    99+
    2024-04-02
  • JavaScript事件流:深入理解事件处理和传播机制
    引言 JavaScript中的事件流是一种机制,用于描述和处理事件在DOM树中的传播过程。了解事件流的属性和工作原理对于编写高效的事件处理代码和实现复杂的交互功能至关重要。本文将详细介绍JavaSc...
    99+
    2023-09-14
    javascript 开发语言 ecmascript 原力计划
  • javascript怎么实现事件处理程序
    JavaScript 是一种脚本语言,主要用于在 Web 页面中实现动态效果和交互性。他可以通过事件处理程序来响应用户在页面上的操作,例如单击、双击、移动鼠标、按下键盘等事件。实现事件处理程序是 JavaScript 中十分重要的技能,以下...
    99+
    2023-05-14
  • 怎么实现javascript延时加载
    本篇内容介绍了“怎么实现javascript延时加载”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • 如何动态加载JavaScript文件
    这篇文章主要介绍如何动态加载JavaScript文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、使用document.write/writeln()方式该种方式可以实现js文件...
    99+
    2024-04-02
  • JavaScript中怎么测试表格组件的加载速度
    这篇文章将为大家详细讲解有关JavaScript中怎么测试表格组件的加载速度,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、表格行数测试首先,针对每种表格...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作