普通函数格式: function add(a,b){return a+b};
箭头函数格式:add =(a,b)=>a+b;或add=(a,b)=>{return a+b;}这里就不详细说明箭头函数的简写规则,2者区别主要分为以下几个方面:
1.this方面:
普通函数内部的this,默认指向window,严格模式下指向undefined;
箭头函数内部的this,与上一级作用域中的this指向同一个地方。
具体示例代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript">
var person = {
name: "小明",
age: 2,
sayname: function() {
setTimeout(function() {
console.log(this)}, 500);
}
}
var person2 = {
name: "小张",
age: 4,
sayname: function() {
setTimeout(()=> {
console.log(this)}, 500);
}
}
person.sayname();
person2.sayname();
</script>
</html>
2.arguments方面:
普通函数,可以通过arguments来实现重载;
箭头函数中,没有arguments,代替它功能是剩余参数rest(...)。
示例代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript">
function add(...values) {
let sum = 0;
for (var val of values) {
sum += val;
}
return sum;
}
alert(add(2, 5, 3)) // 10
</script>
</html>
3.原型对象方面:
普通函数,是有自己的原型对象的;
箭头函数,没有原型对象。
4.new方面:
普通函数,可以作为构造函数,通过new实例化出子函数;
箭头函数,不能作为构造函数,使用new会报错。
网友回复
js如何流式输出ai的回答并折叠代码块,点击代码块右侧可预览代码?
ai大模型如何将文章转换成可视化一目了然的图片流程图图表?
大模型生成html版本的ui原型图和ppt演示文档的系统提示词怎么写?
rtsp视频直播流如何转换成websocket流在h5页面上观看?
为啥coze会开源工作流agent coze studio?
如何检测网页是通过收藏夹打开的?
python如何实现类似php的http动态脚本请求处理响应代码?
js如何实现类似php的http动态脚本请求处理响应代码?
trae与solo有啥区别不同?
vue如何让ai动态生成问卷调查多步骤表单式收集基础信息自动规划执行任务?