1.Function()属性和方法

属性:

prototype

2.Function对象实例属性和方法

实例属性:(例如var Function=function(x,y,z){}; myFunction.length;)

  • arguments
  • constructor
  • length

实例方法(例如var myFunction=function(x,y,z){}; myFunction.toString();)

  • apply()
  • call()
  • toString()

3.函数总有返回值

例如:

  1. var sayHi=function(){
  2. return "hi";
  3. };
  4.  
  5. console.log(sayHi());//返回值为hi

如果没有指定返回值,则会返回undefined。下面调用yelp函数,将字符串yelp返回控制台,且不会显式返回值。

  1. var yelp=function(){
  2. console.log("yeklp");
  3. }
  4. console.log(yelp()===undefined);//true

虽然没有显示的return返回值,但还是有返回值存在的,如果不指定要返回的值,则返回是undefined

4.函数为什么被称为是“一等公民”

  • 函数是对象,可以存储在一个变量、数组或对象中
  • 函数可以传递给函数,并由函数返回。函数拥有属性,因为他是一个对象

5.arguments对象的length属性:调用时发送给函数的参数数量,例如:

  1. var myFunction=function(z,s,d){
  2. return arguments.length;
  3. };
  4. console.log(myFunction());//0

Function()实例的length属性:函数所需要的参数总数量,例如:

  1. var myFunction=function(z,s,d){
  2. return myFunction.length;
  3. }
  4. console.log(myFunction());//

6.定义函数的四种方式:

//函数的构造函数:

var addConstructor=new Function('x','y','return x+y');

//函数声明

function foo(x,y){

return x+y;

}

//函数表达式

var foo=function(x,y){

return x+y;

}

//函数声明表达式

var foo=function add(x,y){

return x+y;

};

7.调用函数的方式:

//函数模式

  1. var foo=function(){
  2. return "foo";
  3. }
  4. console.log(foo());

//方法模式

  1. var myObject={
  2. myFunction:function(){
  3. return "bar";
  4. }
  5. }
  6. console.log(myObject.myFunction());

//构造函数模式

  1. var Cody=function(){
  2. this.living=true;
  3. this.foo=function(){
  4. return this.living;
  5. };
  6. }
  7. var cody=new Cody();
  8. console.log(cody);

//apply和call模式

  1. var great={
  2. runGreet:function(){
  3. console.log(this.name,arguments[0],arguments[1]);
  4. }
  5. }
  6.  
  7. var cody={name:'cody'};
  8. var lisa={name:'lisa'};
  9.  
  10. greet.runGreet.call(cody,'foo','bar');// cody foo bar
  11. greet.runGreet.apply(lisa,['foo','bar']);//lisa foo bar

8.自定义的匿名函数语句

  1. (function(msg){
  2. console.log(msg);
  3. })("Hi");
  4.  
  5. (function(msg){
  6. console.log(msg);
  7. }("Hi"));
  8.  
  9. !function(msg){
  10. console.log(msg);
  11. }("Hi");
  12.  
  13. //以下代码不行
  14. function sayHi(){
  15. console.log("hi");
  16. }();

js中的函数易忽略的点小节的更多相关文章

  1. JS中的函数,Array对象,for-in语句,with语句,自定义对象,Prototype

    一)函数 A)JS中的函数的定义格式: function add(a,b) { var sum = a+b; document.write("两个数的和是:" + sum); // ...

  2. js中的函数,Date对象,Math对象和数组对象

    函数就是完成某个功能的一组语句,js中的函数由关键字 function + 函数名 + 一组参数定义;函数在定义后可以被重复调用,通常将常用的功能写成一个函数,利用函数可以使代码的组织结构更多清晰. ...

  3. js中getByClass()函数

    js中getByClass()函数进化史 对于js来说,我想每一个刚接触它的人都应该会抱怨:为什么没有一个通过class来获取元素的方法.尽管现在高版本的浏览器已经支持getElementsByCla ...

  4. JS中的函数、Bom、DOM及JS事件

    本期博主给大家带来JS的函数.Bom.DOM操作,以及JS各种常用的数据类型的相关知识,同时,这也是JavaScript极其重要的部分,博主将详细介绍各种属性的用法和方法. 一.JS中的函数 [函数的 ...

  5. node.js 中回调函数callback(转载),说的很清楚,看一遍就理解了

    最近在看 express,满眼看去,到处是以函数作为参数的回调函数的使用.如果这个概念理解不了,nodejs.express 的代码就会看得一塌糊涂.比如: 复制代码 代码如下: app.use(fu ...

  6. JS中的函数、BOM和DOM操作

     一.JS中的函数 [关于注释] /** [文档注释]:开头两个*.写在函数上方,在调用函数时可以看到文档上方的描述信息. */   // 单行注释 /* 多行注释 */ 1.函数的声明及调用 (1) ...

  7. html css <input> javaScript .数据类型 JS中的函数编写方式 BOM总结 DOM总结

    Day27  html css div 块标签. 特点: 独占一行,有高度和宽度 span 行元素. 特点:在同一行显示,当前行满了自动去下一行显示. 不识别高度和宽度 1.1.1.1 2.输入域标签 ...

  8. 前端之js中的函数

    函数 函数就是重复执行的代码片.   函数定义与执行 <script type="text/javascript">     // 函数定义     function ...

  9. JS中的函数节流throttle详解和优化

    JS中的函数节流throttle详解和优化在前端开发中,有时会为页面绑定resize事件,或者为一个页面元素绑定拖拽事件(mousemove),这种事件有一个特点,在一个正常的操作中,有可能在一个短的 ...

随机推荐

  1. linux awk数组相关操作介绍

    用awk进行文本处理,少不了就是它的数组处理.那么awk数组有那些特点,一般常见运算又会怎么样呢.我们先看下以下的一些介绍,结合样例我们会解说下它的不同之处.在 awk 中数组叫做关联数组(assoc ...

  2. Redis持久化——RDB(一)

    核心知识点: 1.RDB:将当前数据生成快照保存到硬盘 2.手动触发 save:会阻塞Redis服务器直到RDB完成. bgsave:执行fork创建子进程,由子进程负责RDB操作,阻塞只发生在for ...

  3. || and && 理解

    逻辑或(||): 只要第一个值的布尔值为false,那么永远返回第二个值. 逻辑或属于短路操作,第一个值为true时,不再操作第二个值,且返回第一个值. 逻辑与(&&): 只要第一个值 ...

  4. 深入理解利用new创建对象的执行过程以Person p=new Person("张三",20);为例

    代码如下: class Person { private String name="haha"; private int age; private static String co ...

  5. 【leetcode刷题笔记】Binary Tree Level Order Traversal(JAVA)

    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...

  6. nginx别名配置,状态配置,include优化

    一.nginx帮助参数 下面是关于/application/nginx/sbin/nginx 的参数帮助 [root@A conf]# /application/nginx/sbin/nginx -h ...

  7. SrpingCloud 之SrpingCloud config分布式配置中心

    Config架构 当一个系统中的配置文件发生改变的时候,我们需要重新启动该服务,才能使得新的配置文件生效,spring cloud config可以实现微服务中的所有系统的配置文件的统一管理,而且还可 ...

  8. 算法(Algorithms)第4版 练习 1.4.6

    (1)sum = N + N/2 + N/4 +  …… + 1 假设N是2的倍数(N = 2q),则sum = N -1 ~ N (2)sum = 1+2+……N/2 同(1)分析,sum = N/ ...

  9. Python的进度条的制作

    import sys,time #导入模块 for i in range(50): #进度条的长度 sys.stdout.write("#") #进度条的内容,这里要注意了,pyc ...

  10. BZOJ 3357 [Usaco2004]等差数列:map优化dp

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3357 题意: 给你n个数a[i],让你找出一个最长的是等差数列的子序列. 题解: 表示状态 ...