专注WEB开发 分享经验,沉淀知识

javascript函数参数设置默认值问题

 作者:chenxing  时间:2016-10-12 22:10  阅读:110  评论:

不同浏览器都有自己的js引擎,对待上面这个函数可能表现的还不一样,至少在firefox里执行这个函数是没问题的。不同版本的IE和chrome表现也不一样,较低版本执行如上的函数就会出现错误。我们不能保证用户使用什么的浏览器,所以我们要规避这种陷阱。

在介绍如何设置参数默认值前先判断以下代码是否正确

function Get(param,callback,type='json'){
    ...//代码块
}

这里我在定义函数的时候直接在参数里传递默认值,这样设置函数的默认值是否有问题呢?如果这个是php程序,这样设置很标准。如果是javascript,那就可能会出现问题。

不同浏览器都有自己的js引擎,对待上面这个函数可能表现的还不一样,至少在firefox里执行这个函数是没问题的。不同版本的IE和chrome表现也不一样,较低版本执行如上的函数就会出现错误。我们不能保证用户使用什么的浏览器,所以我们要规避这种陷阱。

那么如何规范的给函数参数加默认值

方式一:通过arguments对象

function Get(param,callback,type){
    var type = arguments[2]?argument[2]:'json';
}

方式二:参数多少使用jquery拓展方式

function Fun(param){
    var defaultParam = {};
    $.extend(param,defaultParam || {});
}

方式三:缺省赋值

function Fun(param){
    var p = param?param:'';
}

以上就是常见的三种方式的函数参数的默认值设置。

最后附上不同浏览器使用的js引擎作为文章拓展知识:

  • WebKit , Safari浏览器 -> SquirrelFish Extreme,
  • Firefox -> TraceMonkey引擎
  • Google Chrome -> V8引擎,(C++)
  • Opera -> Carakan
  • Mozilla -> SpiderMonkey(C语言)
  • Mozilla -> Rhino( Java)
  • Mozilla -> JaegerMonkey

除特别注明外,本网站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/12.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

一年时间又回到这里

 2019-07-27 16:54  157

PHP字符串转数组的三种场景

 2018-05-05 01:32  201

PHP如何遍历字符串?

 2018-05-04 00:56  1333

api接口常见的安全问题和解决方案

 2018-05-03 23:20  994

 最新评论

 lisheng: 05月09日 19:26
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 心态炸裂: 03月24日 10:54
No3.blindcomfirm 多了一个l,望改正!!!
来源: 微信小程序获取input值的总结
 666666: 11月08日 13:49
66666
来源: 一年时间又回到这里
 花花草草: 10月14日 14:58
tp5不是已经提前开了吗
来源: _SESSION变量未定义?
 疯了: 10月10日 13:40
你好呀,我使用docker构建的 把整个项目给了777 并把runtime的所有者给了nginx php的运行者还是报错
来源: thinkphp5的mkdir() Permission denied问题探讨
 mesecretme: 09月30日 15:30
有个问题,有没有发现用redis保存session的话,session清空redis的key还没过期,会依然保留的,这是值变成空了
来源: php项目redis实现session共享案例