发布于 2017-02-01 00:14:41 | 157 次阅读 | 评论: 0 | 来源: 网友投递
这里有新鲜出炉的Javascript教程,程序狗速度看过来!
JavaScript客户端脚本语言
Javascript 是一种由Netscape的LiveScript发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
所有Web前端同仁对 document.getElementById 都非常熟悉了。开发过程中经常需要用其获取页面id为xx的元素,自从元老级JS库Prototype流行后,都喜欢这么简写它
// 方式1
function $(id){ return document.getElementById(id); }
// 方式2
var $ = document.getElementById;
为什么Firefox/Safari/Chrome/Opera 方式2获取就不行呢,原因是这些浏览器中getElementById方法内部实现中需依赖this(document),IE则不需要this。或者说方式2在Firefox/Safari/Chrome/Opera中调用时说丢失了this,以下是个简单示例
// 定义一个函数show
function show(){alert(this.name);}
// 定义一个p对象,有name属性
var p = {name:'Jack'};
show.call(p); // -> 'Jack'
show(); // -> ''
show.call(null); // -> ''<BR>
如果将document.getElementById的 执行环境换成了document而非window,则可以正常的使用$了。如下
// 修复document.getElementById
document.getElementById = (function(fn){
return function(){
return fn.apply(document,arguments);
};
})(document.getElementById);
// 修复后赋值给$,$可正常使用了
var $ = document.getElementById;
// 方式3
var $ = document.getElementById.bind(document);
分析了getElementById的情况,下面的一些方法在各浏览器中的差异原因就很好明白了
var prinf = document.write;
prinf('<h3>Test prinf</h3>'); // IE6/7/8可运行,其它浏览器报错
var prinfln = document.writeln;
prinfln('<h3>Test prinfln</h3>'); // IE6/7/8可运行,其它浏览器报错
var reload = location.reload;
reload(); // IE6/7/8可运行,其它浏览器报错
var go = history.go;
go(-2); // IE6/7/8可运行,其它浏览器报错