js中的函数易忽略的点小节
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.函数总有返回值
例如:
var sayHi=function(){
return "hi";
};
console.log(sayHi());//返回值为hi
如果没有指定返回值,则会返回undefined。下面调用yelp函数,将字符串yelp返回控制台,且不会显式返回值。
var yelp=function(){
console.log("yeklp");
}
console.log(yelp()===undefined);//true
虽然没有显示的return返回值,但还是有返回值存在的,如果不指定要返回的值,则返回是undefined
4.函数为什么被称为是“一等公民”
- 函数是对象,可以存储在一个变量、数组或对象中
- 函数可以传递给函数,并由函数返回。函数拥有属性,因为他是一个对象
5.arguments对象的length属性:调用时发送给函数的参数数量,例如:
var myFunction=function(z,s,d){
return arguments.length;
};
console.log(myFunction());//0
Function()实例的length属性:函数所需要的参数总数量,例如:
var myFunction=function(z,s,d){
return myFunction.length;
}
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.调用函数的方式:
//函数模式
var foo=function(){
return "foo";
}
console.log(foo());
//方法模式
var myObject={
myFunction:function(){
return "bar";
}
}
console.log(myObject.myFunction());
//构造函数模式
var Cody=function(){
this.living=true;
this.foo=function(){
return this.living;
};
}
var cody=new Cody();
console.log(cody);
//apply和call模式
var great={
runGreet:function(){
console.log(this.name,arguments[0],arguments[1]);
}
}
var cody={name:'cody'};
var lisa={name:'lisa'};
greet.runGreet.call(cody,'foo','bar');// cody foo bar
greet.runGreet.apply(lisa,['foo','bar']);//lisa foo bar
8.自定义的匿名函数语句
(function(msg){
console.log(msg);
})("Hi");
(function(msg){
console.log(msg);
}("Hi"));
!function(msg){
console.log(msg);
}("Hi");
//以下代码不行
function sayHi(){
console.log("hi");
}();
js中的函数易忽略的点小节的更多相关文章
- JS中的函数,Array对象,for-in语句,with语句,自定义对象,Prototype
一)函数 A)JS中的函数的定义格式: function add(a,b) { var sum = a+b; document.write("两个数的和是:" + sum); // ...
- js中的函数,Date对象,Math对象和数组对象
函数就是完成某个功能的一组语句,js中的函数由关键字 function + 函数名 + 一组参数定义;函数在定义后可以被重复调用,通常将常用的功能写成一个函数,利用函数可以使代码的组织结构更多清晰. ...
- js中getByClass()函数
js中getByClass()函数进化史 对于js来说,我想每一个刚接触它的人都应该会抱怨:为什么没有一个通过class来获取元素的方法.尽管现在高版本的浏览器已经支持getElementsByCla ...
- JS中的函数、Bom、DOM及JS事件
本期博主给大家带来JS的函数.Bom.DOM操作,以及JS各种常用的数据类型的相关知识,同时,这也是JavaScript极其重要的部分,博主将详细介绍各种属性的用法和方法. 一.JS中的函数 [函数的 ...
- node.js 中回调函数callback(转载),说的很清楚,看一遍就理解了
最近在看 express,满眼看去,到处是以函数作为参数的回调函数的使用.如果这个概念理解不了,nodejs.express 的代码就会看得一塌糊涂.比如: 复制代码 代码如下: app.use(fu ...
- JS中的函数、BOM和DOM操作
一.JS中的函数 [关于注释] /** [文档注释]:开头两个*.写在函数上方,在调用函数时可以看到文档上方的描述信息. */ // 单行注释 /* 多行注释 */ 1.函数的声明及调用 (1) ...
- html css <input> javaScript .数据类型 JS中的函数编写方式 BOM总结 DOM总结
Day27 html css div 块标签. 特点: 独占一行,有高度和宽度 span 行元素. 特点:在同一行显示,当前行满了自动去下一行显示. 不识别高度和宽度 1.1.1.1 2.输入域标签 ...
- 前端之js中的函数
函数 函数就是重复执行的代码片. 函数定义与执行 <script type="text/javascript"> // 函数定义 function ...
- JS中的函数节流throttle详解和优化
JS中的函数节流throttle详解和优化在前端开发中,有时会为页面绑定resize事件,或者为一个页面元素绑定拖拽事件(mousemove),这种事件有一个特点,在一个正常的操作中,有可能在一个短的 ...
随机推荐
- SQL的优化1
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
- 【HTTP】HTPP学习笔记
1.了解web及网络基础 HTTP的诞生 TCP/IP协议族 应用层 FTP文件传输协议 HTTP超文本传输协议 DNS域名系统:IP地址<--->域名 传输层 TCP传输控制协议 三次握 ...
- LeetCode:范围求和||【598】
LeetCode:范围求和||[598] 题目描述 给定一个初始元素全部为 0,大小为 m*n 的矩阵 M 以及在 M 上的一系列更新操作. 操作用二维数组表示,其中的每个操作用一个含有两个正整数 a ...
- Android AbsoluteLayout绝对布局
绝对布局也叫坐标布局,指定元素的绝对位置,因为适应性很差,一般很少用到.可以使用RelativeLayout替代. 常用属性: android:layout_x --------组件x坐标 andro ...
- [原创]java WEB学习笔记43:jstl 介绍,core库详解:表达式操作,流程控制,迭代操作,url操作
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- tornado源码分析
初识tornado 首先从经典的helloword案例入手 import tornado.ioloop import tornado.web class MainHandler(tornado.web ...
- Render树、RenderObject与RenderLayer
Chapter: 呈现树的构建 1. 呈现树与CSS盒子模型千丝万缕的关系 2. 呈现树与DOM树的关系 3. 浏览器构建呈现树的流程 4. Firefox的规则树和样式上下文树 5. 规则树是如何解 ...
- linux swap的添加等等
1. 先说下 swap的卸载 fdisk -l 或者 free -m 看下 swap挂载的是磁盘,还是 文件生成的 如果是系统创建时就分配好的swap,就使用 swapoff /dev/*** 进 ...
- Openldap- 大机群身份验证服务
无论在哪个行业,数据安全永远都是摆在首要地位.尤其是在大数据行业上,谁掌握了数据,谁就有可能成为下个亿万富豪的环境中,数据安全更为重要.大数据的安全可以从哪些地方入手,首先可以在身份验证上面入手.在大 ...
- cookie对比localStorage哪个适合作为网站皮肤存储
cookie对比localStorage哪个适合作为网站皮肤存储 cookie cookie : 一般由服务器生成,可设置失效时间.如果在浏览器生成,默认是关闭浏览器之后失效 存储大小:4k 每次都会 ...