同樣是filter方法為什麼會有差別

同樣是filter方法為什麼會有差別

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://code.jquery.com/jquery-3.5.1.js"></script>
</head>
<body>
    <li>a</li>
    <li>b</li>
    <li>c</li>
    <li>d</li>
    <li>e</li>
    <li>f</li>
    <li>g</li>
    <li>h</li>
    <li>i</li>
</body>
<script>
    var arr = ['apple','banana','orange'];

    $('li').filter(function(a,b,c) {
        console.log(a) //當前索引值
        console.log(b) //當前元素
        console.log(c) //undefined
    })
    arr.filter(function(a,b,c) {
        console.log(a) //當前元素
        console.log(b) //索引值
        console.log(c) //arr數組本身
    })
</script>
</html>

老師為什麼他們的abc是不一樣的 是因為一個是數組 一個是類數組嗎?

如果是的話 

那又是為什麼不讓他們一樣?

正在回答

登陆购买课程后可参与讨论,去登陆

2回答

同学你好,没有专门的小节讲解回调函数,老师这里给同学讲解一下回调函数。如下:

回调函数是指作为参数传递给另一个函数的函数,回调函数会在另一个函数内被调用(或执行)。

举个例子:调用A时传入函数B,B在函数A内部执行,B就被称作是一个回调函数。

http://img1.sycdn.imooc.com//climg/5ed0b1ed09f57f0404870459.jpg

同学可以测试理解下,祝学习愉快~

好帮手慕慕子 2020-05-29 11:38:51

同学你好,因为一个是jQuery中的fliter方法,一个是js中fliter方法,虽然两者的作用都是过滤,但是使用方式,从同学的代码结果可以看出来是存在差别的。

这个是语法规定的,我们需要记住即可。

如果我的回答帮助到了你,欢迎采纳,祝学习愉快~

  • 提问者 阿鴻 #1
    好的了解,那老師我想再請問一個問題 回調函數這東西在前端零基礎還有組件化開發的哪一節有講到嗎
    2020-05-29 11:42:00
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
2.组件化网页开发
  • 参与学习           人
  • 提交作业       1121    份
  • 解答问题       14456    个

本阶段在运用JS实现动态网页开发的基础上,带你深入理解企业开发核心思想,完成一个企业级网页的开发,体验前端工程师的成就感。

了解课程
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师