knockoutJS学习笔记08:表单域绑定

  前面的绑定都是用在基本标签上,这章主要讲表单域标签的绑定。

一、value 绑定

  绑定标签:input text、textarea。

    <p>用户名:<input type="text" data-bind="value:name" /><span data-bind="text:name"></span></p>
    <p>密码:<input type="text" data-bind="value:password" /><span data-bind="text:password"></span></p>
    function UserInfo(){
        var self = this;
        self.name = ko.observable("tom");
        self.password = ko.observable("123456");
    }
    var userInfo = new UserInfo();
    ko.applyBindings(userInfo);

  关于value还有一个参数:valueUpdate,用于设置触发绑定的时机。支持以下值:  

  “change”(默认值) - 当失去焦点的时候更新view model的值,或者是<select> 元素被选择的时候。

“keyup” – 当用户敲完一个字符以后立即更新view model。

“keypress” – 当用户正在敲一个字符但没有释放键盘的时候就立即更新view model。不像 keyup,这个更新和keydown是一样的。

“afterkeydown” – 当用户开始输入字符的时候就更新view model。主要是捕获浏览器的keydown事件或异步handle事件。

上述这些选项,如果你想让你的view model进行实时更新,使用“afterkeydown”是最好的选择。

  例如,我可以将上面的用户名编辑框改为:<input type="text" data-bind="value:name,valueUpdate:‘afterKeydown‘"/> 这样就可以实时更新了。

二、options 绑定

  绑定标签:select。

  例1:options指定项集。

<select data-bind="options:items"></select>
var items = ["item1","item2","item3"];
ko.applyBindings(items);

//添加新项
items.push("item4");

  例2:optionsText:指定要显示的属性的名称;optionsCaption:初始选项;value:被选中的项。

    <select data-bind="options:items,optionsText:‘name‘,optionsCaption:‘请选择...‘,value:selectedValue"></select>
    <div data-bind="text:selectedValue() ? selectedValue().name : ‘未选择‘"></div>
    var data = {
        items:ko.observableArray([{name:"中国",rank:1},{name:"美国",rank:2},{name:"俄罗斯",rank:3}]),
        selectedValue:ko.observable()
    }
    ko.applyBindings(data);

三、selectedOptions 绑定

  绑定标签:multiple select

    <select data-bind="options:items,selectedOptions:selectedItems" multiple="multiple" size="5"></select>
    <div data-bind="text:selectedItems().join(‘,‘)"></div>
    var data = {
        items:ko.observableArray(["中国","美国","俄罗斯"]),
        selectedItems : ko.observableArray(["中国"])
    }
    ko.applyBindings(data);

  selectedOptions表示选中的项。selectedOptions不仅可以支持字符串,还可以像options一样支持对象类型。

四、checked 绑定

  绑定标签:radio、checkbox。

  例1,相同checked属性的radio为一个组。

    <input type="radio" value="basketball" data-bind="checked:sport"/>篮球
    <input type="radio" value="football" data-bind="checked:sport"/>足球
    <input type="radio" value="running" data-bind="checked:sport"/>跑步
    <p>您的选择:<span data-bind="text:getSport()"</p>
    var data = {
        sport:ko.observable("basketball"),
        getSport:function(){
            switch(data.sport()){
                case "basketball":
                    return "篮球";
                case "football":
                    return "足球";
                case "running":
                    return "跑步";
                default:
                    return "暂无";
            }
        }
    }
    ko.applyBindings(data);

  例2:checked可以多选,所以用observableArray。  

    <input type="checkbox" value="basketball" data-bind="checked:sport"/>篮球
    <input type="checkbox" value="football" data-bind="checked:sport"/>足球
    <input type="checkbox" value="running" data-bind="checked:sport"/>跑步
    <p>您的选择:<span data-bind="text:getSport()"</p>
    var data = {
        sport:ko.observableArray(["basketball","football","running"]),
        getSport:function(){
                var sports = data.sport();
                if(!sports){
                    return "暂无";
                }
                return sports.join(",");
        }
    }
    ko.applyBindings(data);

五、enable 绑定/disable 绑定

  根据结果设置input 的 disabled 属性。这两个的作用是一样的。

    <input type="text" data-bind="enable:isEnabled" /><br />
    <input type="button" value="Test" data-bind="disable:isDisabled" />

六、hasfocus 绑定

  结果为true时获得焦点。input text用得比较多。

七、click 和 submit 绑定

  绑定点击事件和提交事件。

  例1:函数第一个参数就是事件对象。

    <input type="button" value="click" data-bind="click:btnClick" />
    var data = {
        btnClick:function(event){
            console.log(event);
        }
    }
    ko.applyBindings(data);

  例2:取消事件冒泡,通过绑定 cancelBubble:false 就可以取消事件冒泡。

    <div data-bind="click:btnClick">
        <input type="button" value="click" data-bind="click:btnClick,clickBubble:false" />
    </div>

  例3:也可以在绑定事件里,传递参数到执行函数,最简单的方式就是用一个匿名函数包装一下。

    <div data-bind="click:btnClick">
        <input type="button" value="click" data-bind="click:function(){btnClick(‘参数1‘,‘参数2‘);}" />
    </div>  

  例4:submit 绑定在form标签上,只有绑定函数return ture时,才会提交表单。而为什么表单用submit绑定而不用普通的click绑定?因为表单绑定有更多的操作,例如按下enter键触发提交操作。

    <form action="Default.aspx" data-bind="submit:submitForm">
        <input type="text" name="name" />
        <input type="submit"/>
    </form>
    var data = {
        submitForm:function(){
            return true;
        }
    }

八、event 绑定

  除了点击事件,ko还支持其它事件的绑定。例如:keypress、mouseover、mouseout等。

    <div style="width:100px;height:100px;background:red;" data-bind="event:{mouseover:divMouseOver,mouseout:divMouseLeave}"></div>
    <div data-bind="text:status"></div>
    var data = {
        divMouseOver:function(event){
            this.status("over");
        },
        divMouseLeave:function(event){
            this.status("out");
        },
        status:ko.observable("未开始")
    }
    ko.applyBindings(data);

九、总结

  ko不仅支持样式绑定,还支持事件绑定,将数据作为核心,我们只需要关注数据的变化和数据的逻辑操作,这大大提高了我们的开发效率。

时间: 2024-11-19 15:01:50

knockoutJS学习笔记08:表单域绑定的相关文章

2017.04 vue学习笔记---08表单控件绑定---基础用法

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <style> div{ margin-bottom: 30px; } </style> <script src="js/vue.js"></script> <

2017.04 vue学习笔记---08表单控件绑定---基础用绑定value

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <style> div{ margin-bottom: 30px; } </style> <script src="js/vue.js"></script> <

jQuery学习笔记(5)--表单域获得焦点和失去焦点样式变化

1 <html xmlns="http://www.w3.org/1999/xhtml"> 2 <head runat="server"> 3 <title></title> 4 <script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script> 5 <style ty

Symfony2学习笔记之表单

对于一个Web开发者来说,处理HTML表单是一个最为普通又具挑战的任务.Symfony2集成了一个Form组件,让处理表单变的容易起来.在这一节里,我们将从基础开始创建一个复杂的表单,学习表单类库中最重要的内容. Symfony2 的Form组件是一个独立的类库,你可以在Symfony2项目之外使用它. 创建一个简单的表单:假设你要创建一个应用程序的todo列表,需要显示一些任务.因为你的用户需要编辑和创建任务,所以你需要创建一个表单.在你开始之前,首先来看通用的Task类,用来表示和存储一个单

[学习笔记]--Jfinal 表单提交附件

最近,项目里面用到了Jfinal 里面的上传附件.Jfinal 的Controller 里面提供了一个 getFile系列方法提供文件上传. 我这里呢,是文件上传和表单参数一起提交.页面类似下图: 这里form表单里面使用了 enctype="multipart/form-data" .先看看Jfinal手册的说明吧!大家看了就知道了 然后还有个问题 如果是表单提交 还不可以用ajax 提交,具体的原因呢也找到了 http://www.oschina.net/question/9410

Bootstrap学习笔记(二) 表单

在Bootstrap学习笔记(一) 排版的基础上继续学习Bootstrap的表单,编辑器及head内代码不变. 3-1 基础表单 单中常见的元素主要包括:文本输入框.下拉选择框.单选按钮.复选按钮.文本域和按钮等. 在Bootstrap框架中,通过定制了一个类名`form-control`,也就是说,如果这几个元素使用了类名"form-control",将会实现一些设计上的定制效果. 1.宽度变成了100% 2.设置了一个浅灰色(#ccc)的边框 3.具有4px的圆角 4.设置阴影效果

Bootstrap 学习笔记 之表单(4 day)

Bootstrap学习到这里,理解了为什么它是一个框架,所谓的框架,目前看来就是它本身提供了一套完整的HTML结构和样式. 我们在使用的时候,只要按照这套规则来搭建HTML结构和加上相应的样式名后就可以了. 今天学习的是表单, Bootstrap 提供了下列类型的表单布局: 垂直表单(默认) 内联表单 水平表单 需要一提的就是表单的状态: 表单控件状态 除了 :focus 状态(即,用户点击 input 或使用 tab 键聚焦到 input 上),Bootstrap 还为禁用的输入框定义了样式,

JS学习笔记7_表单脚本

1.获取表单及表单元素引用的方式 var mForm = document.forms[formName];获取表单引用 mForm.elements[elemName]获取表单元素,如有同名的,则得到一组元素(例如radio button) 2.表单元素的常用属性.方法和事件 属性: name:字段名 value:字段值 type:字段类型,例如button, radio等等 readOnly:设置只读 disabled:设置禁用 方法: focus():获得焦点 blur():取消焦点 事件

Codeigniter入门学习笔记14—表单的验证

很久很久以前学习Codeigniter的笔记记录,很随意,但都是自己记录的,希望对需要的人有所帮助. 本文使用word2013编辑并发布 Postbird | There I am , in the world more exciting! Postbird personal website : http://www.ptbird.cn 表单验证 1.add_user ????] 2.form_check() ???? 3. ? 1.加载 ????$this->load->library('f