KnockOut绑定之Click绑定

 

 example(click绑定)

 Click绑定对DOM元素添加一个函数,当DOM元素被点击的时候调用。在button,input 或者a标签中常用,但其实他适用于任何可见的DOM元素。

    每当你点击button按钮的时候,viewModel 里面的incrementClickCounter() 函数被调用,然后更新 numberOfClicks 的值,然后更新界面

       我们可以调用任何javaScript函数,可以不在view model里面,也可以以someObject.someFunction的形式调用函数。



You've clicked times

    example(传递本身绑定值作为参数)

 在这个例子中有两点要注意:

  • 如果是在一个嵌套的绑定上下文,例如在一个foreach绑定,或者with块绑定,但是你要调用viewmodel下面的函数,这时候你需要一个调用当前节点的父节点,或者直接调用根节点去访问需要调用的函数,语法父节点用$parent,根节点用$root;
  • viewmodel里面用把this用一个self变量表示,相当于this的别名,防止在一些情况下引起的作用域链混乱;



    "foreach: places">
  • "text: $data">

example(把事件传递给click调用的函数)

   这个例子展示了给把事件句柄传递给函数,其中data指的是绑定上下文的值,其实也是指上个例子中的place




example(传递任意参数给调用函数)

"font-size:14px;">
"click:changeEditor($index)">

//    将导致函数在初始化时,点击事件changeEditor()函数就被调用 这种写法是错误的!

  如果你想传任意的参数给调用函数,你可以用一个函数字面量来作为一个参数,意思就是说,click后面你可以传递任何javascript变量,因为javascript语法的特殊形式,一个函数也能作为变量传递,所以可以直接在click后面写一个匿名函数,然后在该函数里面直接调用你想到调用的函数,同时把参数传递过去。





    除了用函数字面量的这种办法,我们还可以用另一种办法,用knockout的绑定函数,语法为函数名.bing(里面可以传递参数);

 

 阻止DOM元素的默认事件

  默认情况下,当你对一个DOM元素绑定一个click事件后,当你点击的时候,他只会执行你的click事件,不会执行该DOM元素的默认事件。例如a标签,当你给他绑定了一个事件后,点击,执行绑定事件,但是他不会跳转该a标签指向的连接,如果你想让它继续执行,可以返回一个true;




"http://www.cnblogs.com/santian/" data-bind="click: myFunction.bind($data, 'param1', 'param2')">
    Click me

   阻止事件冒泡

阻止事件冒泡,用如下语法

"click: myDivHandler">

 

你可能感兴趣的:(KnockOut绑定之Click绑定)