在JavaScript中,函数其实就是对象。对象字面量产生的对象连接到Object.prototype。
函数对象连接到Function.prototype(该原型对象本身连接到Object.prototype)。每个函数
对象在创建时也随带着一个prototype属性。它的值是一个拥有constructor属性且值即为该
函数所创建的对象。
因为函数为对象,所以它可以存放在变量中,对象和数组里,也可以被当做参数传递给
其他函数。
注意:函数与众不同的地方在于它们可以被调用。
二.函数字面量
四部分:
1.保留字function
2.函数名(可以忽略)
3.包围在圆括号中的一组参数
4.包围在花括号中的一组语句
三.调用
调用一个函数将暂停当前函数的执行,传递控制权和参数给新函数。除申明时定义的形式参数
,还有两个附加参数:this和arguments。this非常重要,它的值取决于调用的模式。
四种调用模式:
1.方法调用模式
// 创建myobject。它有一个value属性和一个increment方法
// increment方法接受一个可选的参数。如果参数不是数字,那么默认数字1。
var myobject = {
value: 0 ,
increment:function(inc){
this.value += typeof inc === ‘number’?inc:1;
}
};
myobject.increment();
document.writeln(myobject.value); // 1
myobject.increment(2);
document.writeln(myobject.value); // 3
方法可以用this去访问对象,所以它能从对象中取值或修改对象
2.函数调用模式
// 当函数并非一个对象属性时,那它被当做一个函数来调用
var sum = add(3,4); // sum的值为7
// 给myobject增加一个double方法
myobject.double = function(){
var that = this; // 解决方法
var helper = function(){
that.value = add(that.value,that.value);
};
helper(); //以函数的形式调用helper。
};
// 以方法的形式调用double。
myobject.double();
document.writeln(myobject.getValue()); // 6
3.构造器调用模式
// 创建一个名为quo的构造器函数。 它构造一个带有status属性的对象
var quo = function(string){
this.status = string;
};
// 给quo的所有实例提供一个名为get_status的公共方法。
quo.prototype.get_status = function(){
return this.status;
};
// 构造一个quo实例
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
最后前端到底应该怎么学才好?
如果你打算靠自己摸索自学,那么你首先要了解学习前端的基本大纲,这是你将要学习的主要内容,理解以及掌握好这些内容,便可以找到一份初级的前端开发工作。你还需要有一套完整的前端学习教程,作为初学者最好的方式就是看视频教程学习,初学者容易理解接受。
不要选择买书学习,这样的方式没有几个人能学会,基本都是看不下去书,也看不懂书。如果喜欢看书的学弟,可以买一些经典的书籍作为辅助即可,主要还是以看教程为主。每天抽出固定几个小时学习,做好长期学习的准备。学习编程并不是每天光看视频,你学习编程最重要的目的是为了编写软件产品,提供给大众使用,所以用手写出代码实现功能才是我们要做的事情。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
cn/0f2364db34af4d57b77547b5f312230a.jpg?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3h6aXQ0OTQ4MDE4MzE=,size_16,color_FFFFFF,t_70#pic_center)