JavaScript

原文网址http://513394217.blog.163.com/blog/#m=0

第三个方法真巧妙,而最后一个方法只是换种方式实现了第三种方法。

PS:原博主的文章关于前端的比较多,可以多去看看。

在JS中无论是setTimeout还是setInterval,在使用函数名作为调用句柄时都不能带参数,而在许多场合必须要带参数,这就需要想方法解决。

 

一、采用字符串形式:——(缺陷)参数不能被周期性改变

 

setInterval("foo(id)",1000);

这种方式参数以字符串形式传入,多个参数用+连接,如:

setInterval("expandtab('maintab','"+ca+"')",1000)

二、匿名函数包装

 

window.setInterval(function()    
{
     foo (id);
 }, 
1000);

    这样就可以周期性执行foo(id)这个函数,而且把变量id传递进去;

 

三、定义返回无参函数的函数

function foo(id)
{
   alert(id);
}

function _foo(id)
{
return function()
{
foo(id);
}
}

window.setInterval(_foo(id),1000);

 这 里定义了一个函数_foo,用于接收一个参数,并返回一个不带参数的函数,在这个函数内部使用了外部函数的参数,从而对其调用,不需要使用参数。 在 window. setInterval函数中,使用_foo(id)来返回一个不带参数的函数句柄,从而实现了参数传递的功能。

 


四、修改setInterval

 

function foo(id)
{
alert(id);
}

var _sto = setInterval;  
 
window.setInterval = function(callback,timeout,param)
{  
var args = Array.prototype.slice.call(arguments,2);  
var _cb = function()
{  
callback.apply(null,args);  
}   
 
_sto(_cb,timeout);  
}
 
window.setInterval(hello,3000,userName);

 

以上的所有方法也适合setTimeout。

===================================================================================

一点总结:

一、表单提交之前,form可以在onsubmit处进行验证,若此处返回false则不会提交。

二、js中的类可以new 一个object,然后o.value1, o.func2等直接定义成员变量和成员函数等,不用特意声明;但这样会得到一个类,而不是对象,js中对象的实现方式应该是一个工厂方式,即function createXXX{},里面不停new一个新类,只是这样的弊端在于每个对象都会有一个自己的方法,而实际上这是不必要的;第三种方法就是new一个function(或object),区别对待成员变量和成员函数,o.value1和o.prototype.func2。最后则是json的方式来呈现,这个是用于和后台交互对象,可以通过js的eval()还原成一个对象。

其实,java的对象就是一组数据集合。

三、dom主要是三个方法进行定位,document.getElementById,getElementByClassName和getElementByTagName

四、js使用正则表达式,t = new RegExp(""),然后用t.test和t.exec。

五、navigator可以或许浏览器、系统相关的基础信息,譬如codename等等,但是这些信息不可信,因为可以被人为改变,因此进行判定的选择应该是调用该浏览器的特有函数,如果存在,则可以确认。

六、cookie的格式,变量名=值;expire=GMT时间(若删除cookie则把时间设为1970-1-1,UNIX的诞生时间,这是一个故事);path=/(全站都可访问,设为/ducument则只有对应目录可以访问);domain=.qq.com(控制可访问的网站域名,前面的则www.qq.com和web.qq.com都可访问)。如果在一列设置多个值,则可以username=name1^password=password1;expire=GMT时间;path=/;domain=.qq.com这种方式。

七、function x(){(globle) a = 2; functiony(){ alert(a); var a = 1; alert(a);}}结果是先后弹出 undefined和1,原因是js也会首先检查声明,在function y中是存在本地变量a的,因此放弃使用全局变量a(声明时候不加var默认是global的,即global x和x都会是全局变量),但是执行到第一个alert的时候,它并没有发现什么a的声明,因此会得到undefined的结果。

你可能感兴趣的:(JavaScript)