knockoutjs十二 textInput绑定

knockoutjs十二 textInput绑定

今天讲解的是textInput绑定,这其实和value绑定是一样的,但是比value的双向绑定强一点

<div class="container">
        <p>Login name:
            <input data-bind="textInput: userName" />
        </p>
        <p>Password:
            <input type="password" data-bind="textInput: userPassword" />
        </p>


        ViewModel:
        <pre data-bind="text: ko.toJSON($root, null, 2)"></pre>



    </div>
    <script>
        function Model() {
            var self = this;
            self.userName = ko.observable(""); // Initially blank
            self.userPassword = ko.observable("abc"); // Prepopulate
        }
        var model = new Model();
        ko.applyBindings(model);
    </script>

可以从这个例子看到,textinput是view改变后,model是立即改变的,官方推荐在绑定<input> or <textarea>的时候大家使用textinput,因为他不仅可以即时更新,而且可以解决很多浏览器兼容问题,很多浏览器对于剪切,拖拽,或者是接受自动补全这些机制有很大的不同,即时使用了valueUpdate来控制更新时期,还是有可能会不一致,textinput就是专门设计来解决各浏览器之间的不同和即时更新的。
这是官网的话,如果对于事件操作的一致性有很高的要求,确实应该用这个,不然在每个浏览器都有可能反应不一样。听官网的话没有错奥!!!!
其他的属性和value完全一至,就不再赘诉,但是要记住,不要value和textinput在同一个元素使用,那么两个都不会起作用。

今天的就讲解完了,代码托管在https://github.com/lushunming/knockoutJSDemo.git可以直接克隆。希望大家有意见可以留言,我前几天看了下我的博客,发现还是有很多小错误的,希望大家发现错误可以留言告诉我,我会立即改正,防止把错误东西传播出去,有疑问或者错误可以加我的qq1357197829和我交流。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
KnockoutJS是一个JavaScript库,它使用观察者模式来实现数据绑定。观察者模式是一种设计模式,其中一个对象(称为观察者)监视另一个对象(称为主题)的状态变化,并在状态变化时自动更新。在KnockoutJS中,你可以使用ko.observable()函数来创建可观察的属性。这些可观察属性可以与HTML元素的数据绑定属性进行连接,使得当属性的值发生变化时,相关的UI元素也会自动更新。这种自动更新的机制使得实现响应式UI变得非常简单。此外,KnockoutJS还提供了其他特性,如自动追踪依赖关系、模板化和可扩展性,使得开发者可以更方便地构建复杂的UI结构和自定义行为。 #### 引用[.reference_title] - *1* [Knockoutjs官网翻译系列(一)](https://blog.csdn.net/dewda477315271666/article/details/102130157)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Angular vs. KnockoutJS:您应该知道的基本差异和相似之处](https://blog.csdn.net/cullen2012/article/details/108488066)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [KnockoutJS学习与应用](https://blog.csdn.net/qq845484236/article/details/103870985)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

machineShunMing

谢谢老板

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值