注意:函数名仅仅是一个包含指针的变量而已

函数内部属性

arguments 和this 两个特殊对象

arguments:类数组对象,包含出入函数中的所有参数,主要用途是保存函数参数

callee:该属性是一个指针,指向拥有这个arguments对象的函数,在严格模式下运行,会导致错误

例:function factorial(num){

      if(num<=1)

        return 1;

else

         return num*(factorial(num-1))

}

此处用了递归算法,若函数名不变则没有问题,但是函数名变化,那么内部的名字也要变,存在耦合关系,为了消除这种耦合,可以使用callee

    function factorial(num){

      if(num<=1)

        return 1;

else

         return num*arguments.callee(num-1)

}

函数的属性和方法:

每个函数都包含该两个属性

length:表示函数希望接收的命名参数的个数

prototype:toString()和valueOf()等方法实际都保存在prototype名下,在创建自定义类型以及实现继承时,该属性都是极为重要的

每个函数都包含两个非继承而来的方法

apply:接收两个参数:一个是运行函数的作用域,另个参数是参数数组 或者 arguments对象

call():基本和apply相同,但是除了this外,传递给函数的参数必须逐个列举出来

例:function sum(num1,num2){ return num1+num2}

function applySum1(num1,num2){ return sum.apply(this , arguments)} 或者arguments替换为[num1,num2]

例:function callSum(this,num1,num2){ return sum.call(this,num1,num2)};

call()和apply()强大的地方是扩充函数赖以运行的作用域

例如 :

window.color=red;     var o={ color :blue}

function sayColor(){ alert (this.color)}

sayColor.call(this);//red

sayColor.call(window);//red

sayColor.call(o);//blue

bind()方法:兼容性 ie9+,firefox4,safari5.1.....

var objectSayColor=sayColor.bind(o); objectSayColor();//blue

基本包装类型:Boolean,Number,String

String: 字符串是基本类型值,不应该存在方法,但为了这种直观的操作,后台已经做了处理

例:var s1=' some text '

var s2= s1.substring(2);

可以理解为:(1)创建String类型的实例  (2)在实例上调用指定的方法 (3)销毁这个实例

例:var s1=new String(' some text')   var s2=s1.substring(2)    s1=null;

Boolean:该实例重写了valueOf()方法,返回基本类型值true或false,重写了toString()方法,返回字符串‘true’ 或‘false’,在实际中不怎么用到

var falseObject=new Boolean(false);

var result = falseObject && true;  //返回true

注意:所有对象都会被转为true

Number:也重写了valueOf(),toLocaleString()和toString()方法

toFixed()://一般带有0-20个小数位

例:var  num= 10   num.toFixed(2);   //10.00        var num=10.005   num.Fixed(2) //10.01 对多处的小数位进行四舍五入

javascript 之 函数的更多相关文章

  1. JavaScript中函数函数的定义与变量的声明<基础知识一>

    1.JavaScript中函数的三种构造方式 a.function createFun(){ } b.var createFun=function (){ } c.var createFun=new ...

  2. 理解 JavaScript 回调函数并使用

    JavaScript中,函数是一等(first-class)对象:也就是说,函数是 Object 类型并且可以像其他一等对象(String,Array,Number等)一样使用.它们可以"保 ...

  3. 5种 JavaScript 调用函数的方法

    一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正理解Javascript函数是如何工作而导致的(顺便说一下,许多那样的代码是我写的).JavaScript拥有函数式编程的特性 ...

  4. javascript escape()函数和unescape()函数

    javascript escape()函数和unescape()函数 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法: escape(string) stri ...

  5. JavaScript调用函数的方法

    摘要:这篇文章详细的介绍了Javascript中各种函数调用的方法及其原理,对于理解JavaScript的函数有很大的帮助! 一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正 ...

  6. Javascript常用方法函数收集(二)

    Javascript常用方法函数收集(二) 31.判断是否Touch屏幕 function isTouchScreen(){ return (('ontouchstart' in window) || ...

  7. javascript工具函数

    第一部分 JavaScript工具函数 转义特殊字符为html实体   HtmlEncode: function(str){ return str.replace(/&/g, '&') ...

  8. [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢?   原因在于: ...

  9. javascript篇-----函数作用域,函数作用域链和声明提前

    在一些类似C语言的编程语言中,花括号内的每一段代码都具有各自的作用域,而且变量在声明它们的代码段之外是不可见的(也就是我们不能在代码段外直接访问代码段内声明的变量),我们称之为块级作用域,然而,不同于 ...

  10. JavaScript 常用函数总结

    javascript函数:  ·常规函数  ·数组函数  ·日期函数  ·数学函数  ·字符串函数 .cookie函数 1.常规函数 javascript常规函数包括以下9个函数:  (1)alert ...

随机推荐

  1. ROS串口通信

    身处机器人行业,不想一直只做低端的单片机控制,老是待在舒适区,所以一直都想学一下ROS系统,但看了几个月资料后,感觉还是云里雾里,似懂非懂,感念似乎都很清楚,但要实际去做,却又感觉无从下手. 于是想先 ...

  2. TZOJ 5271: 质因数的个数

    求正整数N(N>1)的质因数的个数. 相同的质因数需要重复计算.如120=2*2*2*3*5,共有5个质因数. 输入 可能有多组测试数据,每组测试数据的输入是一个正整数N,(1<N< ...

  3. ffmpeg 多个音频合并 截取 拆分

    1 多个mp3文件合并成一个mp3文件 一种方法是连接到一起 ffmpeg64.exe -i "concat:123.mp3|124.mp3" -acodec copy outpu ...

  4. DHCP服务器 出现的故障

    系统版本:Windows Server 2008 R2 Standard 故障现象:近段时间,我们核心网络DHCP服务器,总是发现有掉线重起现象,大约每10分钟至30分钟不定时会重起. 故障代码:关键 ...

  5. B. Lynyrd Skynyrd

    传送门: 题意:给出 n,m,q 然后给出模板串,从1-n数字只出现一次,然后给出长度为m的要询问的串. q组询问:每组询问输出 ‘1’或者‘0’ 每组询问 一对x,y    问在x到y中有没有模板串 ...

  6. Jsoup解析XML

    先导入jsoup.jar  包 方法1:不推荐,了解即可 方法 方法3: 后期学习主流

  7. 自定义bash提示符

    http://adamcavendish.is-programmer.com/posts/35659.html

  8. Carthage 让项目支持及使用,第三方静态库转为动态库

    Carthage介绍 具体使用,可以查看官网的,文档地址 https://github.com/Carthage/Carthage.如果看不懂英文,可以看一下官文的翻译:https://www.jia ...

  9. win 下 python ImportError: No module named requests

    第一次弄爬虫,报库找不到,网上找了半天,一般都让都让改成绝对路径...那不是饮鸩止渴嘛. 然后 在无意中发现,不需要控制台输入pip命令,因为不是在Linux下啊,,win下直接在pycharm里添加 ...

  10. STM32F103驱动GT911

    0x00 引脚连接: // SCL-------PB10 // SDA-------PB11 // INT--------PB1 // RST--------PB2 IIC的SCL与SDA需要接上拉电 ...