JavaScript中DOM详解


Posted in Javascript onApril 13, 2015

为了达到平稳退化,向后兼容,标记分离的思想,每次写js代码时做的第一件事应该是必要的测试和检查工作:
在js文件里首先添加以下代码进行检查:

window.onload = function(){
if(!document.getElementsByTagName)  return false;
if(!document.getElementById) return false;
if(!document.getElementsByClassName)  return false;
if(!document.getElementById("selector"))  return false;
if(!document.getElementsByTagName("tag"))  return false;
if(!document.getElementsByClassName("selector"))  return false;
};

通用封装函数:

var $ = function(id){
   return document.getElementBy Id (id);
}
var addEvent = function(obj,event,fn){  //obj:元素对象名字,event:绑定事件,fn:触发的回调函数
   if(obj.addEventListener){
obj.addEventListener(event,fn,false);
   }
   else if(obj.attachEvent){
obj.attachEvent("on"+event,fn);
   }
}

对于很多函数需要页面加载即运行,window.onload封装方法如下:

function addLoadEvent(func){
var oldonload = window.onload;
if(typeof window.onload != "function")
{
window.onload = func;
}
else
{
window.onload = function()
{
oldonload();
func();
}
}
}
addLoadEvent(firstFunction);
addLoadEvent(secondFunction);

火狐和IE之间的JavaScript差异

1、在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默认情况下点击一个a元素,页面会跳转到该元素href属性指定的页。
return false 就相当于终止符,return true 就相当于执行符。
在js中对于return用法的三种景象的总结如下:
retrun true; 返回正确的处理惩罚成果。
return false;返回错误的处理惩罚成果;终止处理惩罚;阻拦提交表单;阻拦履行默认的行动。
return;把把握权返回给页面。

2、在绝大多数时候,把一个函数调用赋值给一个变量将是一个好主意。

3、noscript标签可被用于可识别 script标签但无法支持其中的脚本的浏览器。如果浏览器支持脚本,那么它不会显示出 noscript 标签中的文本。

4、在动态设置样式时,只要有可能,最好选用CSS,最简单的就是选择最容易实现的方法。

5、在一个函数中会用到全局对象存储为局部变量来减少全局查找,因为访问局部变量的速度要比访问全局变量的速度更快些。

6、如果针对的是不断运行的代码,不应该使用setTimeout,而应该是用setInterval,因为setTimeout每一次都会初始化一个定时器,而setInterval只会在开始的时候初始化一个定时器。

7、如果要连接多个字符串,应该少使用+= ,条件分支时尽量使用三目运算符替代条件分支。

8、很多人喜欢使用parseInt(),其实parseInt()是用于将字符串转换成数字,而不是浮点数和整型之间的转换,我们应该使用Math.floor()或者Math.round()。

9、在JavaScript中所有变量都可以使用单个var语句来声明,这样就是组合在一起的语句,以减少整个脚本的执行时间。

10、对于大的DOM更改,使用innerHTML要比使用标准的DOM方法创建同样的DOM结构快得多。

11、当同一个对象使用.onclick的写法触发多个方法的时候,后一个方法会把前一个方法覆盖掉,也就是说,在对象的onclick事件发生时,只会执行最后绑定的方法。而用事件监听则不会有覆盖的现象,每个绑定的事件都会被执行。

12、如果定义了toString()方法来进行类型转换的话,推荐显式调用toString(),因为内部的操作在尝试所有可能性之后,会尝试对象的toString()方法尝试能否转化为String,所以直接调用这个方法效率会更高。

13、因为elemet.style只能获取内联样式,而element.currentStyle.width是IE浏览器专有属性,getComputedStyle(element, null).width是火狐和Chrome浏览器的特有属性,所以为了兼容,获取内外样式方法如下(不可取复合样式,如background,border,而是应该写成backgroundColor,borderWidth):

function getStyle(obj,name) {
   if(obj.currentStyle) {
     return obj.currentStyle[name];
   }
   else
   {
     return getComputedStyle(obj,null)[name];
   }
}

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
js向上无缝滚动,网站公告效果 具体代码
Nov 18 Javascript
B/S模式项目中常用的javascript汇总
Dec 17 Javascript
JavaScript实现存储HTML字符串示例
Apr 21 Javascript
javascript给span标签赋值的方法
Nov 26 Javascript
js判断某个字符出现的次数的简单实例
Jun 03 Javascript
浅谈Cookie的生命周期问题
Aug 02 Javascript
简单谈谈CommonsChunkPlugin抽取公共模块
Dec 31 Javascript
JavaScript捕捉事件和阻止冒泡事件实例分析
Aug 03 Javascript
js实现搜索栏效果
Nov 16 Javascript
JS中的算法与数据结构之队列(Queue)实例详解
Aug 20 Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
Oct 09 jQuery
vue 数据操作相关总结
Dec 17 Vue.js
js 获取元素在页面上的偏移量的方法汇总
Apr 13 #Javascript
javascript中scrollTop详解
Apr 13 #Javascript
jQuery实现的在线答题功能
Apr 12 #Javascript
jQuery插件bxSlider实现响应式焦点图
Apr 12 #Javascript
jQuery插件Skippr实现焦点图幻灯片特效
Apr 12 #Javascript
jQuery插件pagination实现分页特效
Apr 12 #Javascript
jQuery插件multiScroll实现全屏鼠标滚动切换页面特效
Apr 12 #Javascript
You might like
DIY一个适配电脑声卡的动圈话筒放大器
2021/03/02 无线电
PHP检查网站是否宕机的方法示例
2017/07/24 PHP
PHP实现redis限制单ip、单用户的访问次数功能示例
2018/06/16 PHP
启用OPCache提高PHP程序性能的方法
2019/03/21 PHP
灵活应用js调试技巧解决样式问题的步骤分享
2012/03/15 Javascript
探讨jQuery的ajax使用场景(c#)
2013/12/03 Javascript
jQuery简单图表peity.js使用示例
2014/05/02 Javascript
JavaScript中数组成员的添加、删除介绍
2014/12/30 Javascript
javascript实现保留两位小数的多种方法
2015/12/18 Javascript
NodeJS远程代码执行
2016/08/28 NodeJs
利用Angularjs和bootstrap实现购物车功能
2016/08/31 Javascript
AngularJS中如何使用echart插件示例详解
2016/10/26 Javascript
解析Javascript单例模式概念与实例
2016/12/05 Javascript
vue v-on监听事件详解
2017/05/17 Javascript
Web技术实现移动监测的介绍
2017/09/18 Javascript
node.js读取Excel数据(下载图片)的方法示例
2018/08/02 Javascript
详解微信小程序与内嵌网页交互实现支付功能
2018/10/22 Javascript
微信公众号H5支付接口调用方法
2019/01/10 Javascript
es6函数之严格模式用法实例分析
2020/03/17 Javascript
多页vue应用的单页面打包方法(内含打包模式的应用)
2020/06/11 Javascript
[01:06:07]2014 DOTA2国际邀请赛中国区预选赛5.21 DT VS CIS
2014/05/22 DOTA
使用 Python 获取 Linux 系统信息的代码
2014/07/13 Python
用Python写冒泡排序代码
2016/04/12 Python
Python手机号码归属地查询代码
2016/05/04 Python
go和python变量赋值遇到的一个问题
2017/08/31 Python
Flask框架响应、调度方法和蓝图操作实例分析
2018/07/24 Python
Python使用pickle模块报错EOFError Ran out of input的解决方法
2018/08/16 Python
解决Django提交表单报错:CSRF token missing or incorrect的问题
2020/03/13 Python
New Balance英国官方网站:始于1906年,百年慢跑品牌
2016/12/07 全球购物
GAP阿联酋官网:GAP UAE
2017/11/30 全球购物
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
教师先进事迹材料
2014/12/16 职场文书
python自然语言处理之字典树知识总结
2021/04/25 Python
Python 机器学习工具包SKlearn的安装与使用
2021/05/14 Python
使用Redis实现分布式锁的方法
2022/06/16 Redis
Oracle中日期的使用方法实例
2022/07/07 Oracle