w3cschool上的一个示例代码,参数问题?

发布于 2022-09-01 22:10:55 字数 980 浏览 30 评论 0

今天在群里聊天,有个骚年提了一个问题,对w3cschool上的一个click时间的示例demo不解,我自己去看了下,发现也不懂,就是里面函数的参数问题,先贴代码。

<html>

<head>
    <script src="//cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $("div").click(function () {
                $(this).css(
                    "width",
                    function (index, value) {
                        return parseFloat(value) * 1.2;
                    }
                );
            });
        });
    </script>
    <style>
        div {
            width: 100px;
            height: 50px;
            background-color: red;
        }
    </style>
</head>

<body>
    <div>请点击这里</div>
</body>

</html>

我的疑问是:这里的index参数有什么作用?indexvalue的值是哪里来的?如果我去掉index,后面的value就会取不到值,为什么?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

隔纱相望 2022-09-08 22:10:55

这两个参数是jquery给你的

它的css方法接受第二个参数作为回调

可以看下文档 http://api.jquery.com/css/#css-propertyName-function
你使用的是:.css( propertyName, function )

propertyName
Type: String
A CSS property name.
function
Type: Function( Integer index, String value ) => String or Number
A function returning the value to set. this is the current element. Receives the > > index position of the element in the set and the old value as arguments.

对于propertyName我们没有疑义,第二个参数是一个回调函数,它的返回值是你希望给那个元素设置的值,接受字符串或者数值作为返回结果,然后回调此函数时会传给你两个参数,第一个就是要设置的目标元素在你的选择器中的索引,第二个参数是那个目标元素的原有值

我很OK 2022-09-08 22:10:55

1)首先问题click无关
2)这是个jQuery css方法调用问题
.css(prop,fun)
图片描述

fun函数的参数为index,value
index为当前jQuerselector得到的集合索引值,value表示当前prop被修改前的值
func返回修改后的值,作为prop css属性的值
3)你去掉index,那么value不是取不到值,而是它的值为正确调用下的index值,而正确调用下的value被丢弃了

世界如花海般美丽 2022-09-08 22:10:55

首先, function (index, value) 属于一个回调函数,是对选取的 divwidth 修改取值的回调。

为什么有 index ? 因为这里 $("div") 选取的 div 可能会是多个的,那对每一个 div 都会单独执行这个回调函数,而区别这些 div 主要就通过 index 这个参数,其实就是一个识别序号。

为什么去掉 index 就不能正常取值 ? Js 里的回调函数比较智能,允许定义时省略后面的参数,但是不能省略前面的参数,如果你定义成 function (value) ,调用的时候也不会把 value 放到前面来,而是把原来 index 的值传给 value 。其实 indexvalue 这两个参数名无关紧要,名字可以随便定义,重要的是记住传递参数的实际意义,而这些是JQ手册里应该提供的。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文