KnockoutJS 3.X API 第四章 表單綁定(10) textInput、hasFocus、checked綁定

来源:http://www.cnblogs.com/smallprogram/archive/2016/10/11/5948340.html
-Advertisement-
Play Games

textInput綁定目的 textInput綁定主要用於或者元素。他提供了DOM和viewmodel的雙向更新。不同於value綁定,textinput綁定是實時更新的。 例如: Login name: Password: ViewModel: 源碼: Login name: Password: ... ...


textInput綁定目的

textInput綁定主要用於<input>或者<textarea>元素。他提供了DOM和viewmodel的雙向更新。不同於value綁定,textinput綁定是實時更新的。

例如:

Login name:

Password:

ViewModel:

源碼:

<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>
 
<script>
    ko.applyBindings({
        userName: ko.observable(""),        // Initially blank
        userPassword: ko.observable("abc")  // Prepopulate
    });
</script>

備註1:textInput綁定 VS value綁定

雖然value結合也可以進行雙向文本框和視圖模型性能的結合,但是博主更喜歡textInput,因為他是實時更新的。value綁定與textInput綁定的主要的區別在於:

  • 即時更新

    value預設情況下,只有當用戶將焦點從文本框移開後才會更新您的模型。textInput每次擊鍵或其他文本輸入時立刻更新模型。

  • 瀏覽器的事件處理

    不同的瀏覽器有著文本輸入機制,如剪切,拖動,或接受自動完成建議的事件在不同的瀏覽器中機制是不一致。value綁定,有額外的選項,如valueUpdate: afterkeydown獲得對特定事件的更新,但是有可能不相容所有的瀏覽器。

    textInput結合是專門用來處理各種瀏覽器的不同機制,即使在應對不同的文字輸入機制也能保持一致和直接更新模型。

    不要嘗試使用valuetextInput在相同的元素上進行綁定。

     

    hasFocus綁定目的

    hasFocus綁定是視圖模型屬性與DOM元素的焦點狀態綁定。它是一個雙向綁定,所以:

  • 如果您的視圖模型屬性設置為true或者false,相關的元素將成為聚焦的或未聚焦。
  • 如果用戶手動對焦或unfocuses相關元件,所述視圖模型屬性將被設置為truefalse相應。

    如果您正在構建中,編輯元素動態顯示覆雜的形式,你想控制,用戶應該開始打字,或插入符的響應位置,這是非常有用的。

    示例1

    這個例子中當文本框當前具有焦點時則顯示消息,並可以使用一個按鈕通過編程方式觸發焦點。

    The textbox has focus

    源碼:

    <input data-bind="hasFocus: isSelected">
    <button data-bind="click: setIsSelected">Focus programmatically</button>
     <span data-bind="visible: isSelected">The textbox has focus</span> 
    <script>
    var viewModel = {
        isSelected: ko.observable(false),
        setIsSelected: function() { this.isSelected(true) }
    };
    ko.applyBindings(viewModel,document.getElementById("eq2"));
    </script>

    示例2

    因為hasFocus綁定是雙向綁定,這可以使切換的“編輯”模式更加便捷。

    Name:  

    Click the name to edit it; click elsewhere to apply changes.

    源碼:

    <p>
        Name: 
        <b data-bind="visible: !editing(), text: name, click: edit">&nbsp;</b>
        <input data-bind="visible: editing, value: name, hasFocus: editing" />
    </p>
    <p><em>Click the name to edit it; click elsewhere to apply changes.</em></p>
    <script>
    function PersonViewModel(name) {
        // Data
        this.name = ko.observable(name);
        this.editing = ko.observable(false);
             
        // Behaviors
        this.edit = function() { this.editing(true) }
    }
     
    ko.applyBindings(new PersonViewModel("Bert Bertington"),document.getElementById("eq3"));
    
    </script>

    checked綁定目的

    checked綁定主要用於覆選框(<input type='checkbox'>)或單選按鈕(<input type='radio'>) 並與視圖模型屬性進行綁定。

    當用戶更改了表單控制項,這將更新您的視圖模型屬性的值。同樣,當您更新您的視圖模型的值,也將直接反映到表單控制項上。

    註意:對於文本框,下拉列表,以及所有以非可勾選表單控制項,需要使用value綁定或者textInput綁定讀寫元素的值,而不是checked綁定。

    示例1:覆選框綁定

    Send me spam:

    源碼:

    <p>Send me spam: <input type="checkbox" data-bind="checked: wantsSpam" /></p>
     
    <script type="text/javascript">
        var viewModel = {
            wantsSpam: ko.observable(true) // Initially checked
        };
     
        // ... then later ...
        viewModel.wantsSpam(false); // The checkbox becomes unchecked
    </script>

    示例2:多覆選框附帶數組綁定

    Send me spam:

    Preferred flavors of spam: Cherry Almond Monosodium Glutamate

    源碼:

    <p>Send me spam: <input type="checkbox" data-bind="checked: wantsSpam" /></p>
    <div data-bind="visible: wantsSpam">
        Preferred flavors of spam:
        <div><input type="checkbox" value="cherry" data-bind="checked: spamFlavors" /> Cherry</div>
        <div><input type="checkbox" value="almond" data-bind="checked: spamFlavors" /> Almond</div>
        <div><input type="checkbox" value="msg" data-bind="checked: spamFlavors" /> Monosodium Glutamate</div>
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            wantsSpam: ko.observable(true),
            spamFlavors: ko.observableArray(["cherry","almond"]) // Initially checks the Cherry and Almond checkboxes
        };
     
        // ... then later ...
        viewModel.spamFlavors.push("msg"); // Now additionally checks the Monosodium Glutamate checkbox
    </script>

    示例3:單選按鈕

    Send me spam:

    Preferred flavor of spam: Cherry Almond Monosodium Glutamate

    源碼:

    <p>Send me spam: <input type="checkbox" data-bind="checked: wantsSpam" /></p>
    <div data-bind="visible: wantsSpam">
        Preferred flavor of spam:
        <div><input type="radio" name="flavorGroup" value="cherry" data-bind="checked: spamFlavor" /> Cherry</div>
        <div><input type="radio" name="flavorGroup" value="almond" data-bind="checked: spamFlavor" /> Almond</div>
        <div><input type="radio" name="flavorGroup" value="msg" data-bind="checked: spamFlavor" /> Monosodium Glutamate</div>
    </div>
     
    <script type="text/javascript">
        var viewModel = {
            wantsSpam: ko.observable(true),
            spamFlavor: ko.observable("almond") // Initially selects only the Almond radio button
        };
     
        // ... then later ...
        viewModel.spamFlavor("msg"); // Now only Monosodium Glutamate is checked
    </script>

    參數

    • 主要技術參數

      KO設置元素的選中狀態,以配合您的參數值。任何以前選中的狀態將被覆蓋。您的參數被解釋的方式取決於你綁定元素是什麼類型:

      • 對於覆選框,當參數值true時KO將設置為元素為選中狀態,當它為false則為未選中狀態。如果你給定的不是一個布爾值,KO會鬆散地解釋。這意味著,非零數字和非null對象和非空字元串都將被解釋為true,而零,nullundefined,和空字元串將被解釋為false

        當用戶選中或取消選中該覆選框,將KO你的模型屬性設置為truefalse

        如果你的參數解析為一個被給予array數組。在這種情況下,KO將設置檢查DOM中value屬性是否與數組值匹配,如果值匹配則被選中,如果不匹配則不勾選。

        當用戶選中或取消選中該覆選框,將KO更改對應視圖模型屬性的值。就像示例2一樣。

      • 對於單選按鈕,KO將檢查視圖模型的值是否等於單選按鈕DOM節點的value屬性或檢查視圖模型屬性值是否等於checkedValue參數指定的值。就像示例3一樣。

        當選擇了用戶改變其單選按鈕,KO會設置模型屬性值為選定的單選按鈕的值。像示例3中,點擊value="cherry"的單選按鈕後將設置viewModel.spamFlavor"cherry"

      如果你的參數是監控屬性類型,每當值改變綁定將更新元素的選中狀態。如果該參數是非監控屬性,它只會在首次運行時設置元素的選中狀態,以後再不會更新。

    • 其他參數

      • checkedValue

        checkedValue參數定義了使用值與checked綁定結合,而不是元素的value屬性。如果你想要的值是一個字元串(如整數或對象)以外的東西,或者你想動態設置的值,這非常有用。

        例如下邊的例子:

        源碼:

  • <!-- ko foreach: items -->
        <input type="checkbox" data-bind="checkedValue: $data, checked: $root.chosenItems" />
        <span data-bind="text: itemName"></span>
    <!-- /ko -->
     
    <script type="text/javascript">
        var viewModel = {
            items: ko.observableArray([
                { itemName: 'Choice 1' },
                { itemName: 'Choice 2' }
            ]),
            chosenItems: ko.observableArray()
        };
    </script>

    如果你的checkedValue參數是一個監控屬性,當值的變化和元素是否被選中,綁定將更新checked模型屬性。對於覆選框,它會從數組刪除舊值並添加新的價值。對於單選按鈕,它只會更新模型值。


    您的分享是我們最大的動力!

    -Advertisement-
    Play Games
    更多相關文章
    • 下麵賦上代碼對應的文件路徑 ...
    • atitit.Servlet2.5 Servlet 3.0 新特性 jsp2.0 jsp2.1 jsp2.2新特性 1.1. Servlet和JSP規範版本對應關係:1 1.2. Servlet2.5一些變化的介紹: 1 1.3. Jsp2.02 1.4. Jsp2.12 1.5. Jsp2.2 ( ...
    • 在寫介面實現時,有時會有多個實現類。這篇文章介紹在調用時通過傳入字元串來指定具體的實現類。 一.介面與實現類: 在實現類中重寫了toString() 方法,可以自定義字元串,當調用時傳入指定的字元串就能獲取到相應的bean。 二.register書寫: 三.測試類: 運行結果,如圖: 備註: 在sp ...
    • 一 PYTHON 安裝 1. Python下載 (1) www.python.org官網 (2) 選擇可執行文件( 64位3.5.2Windows x86-64 executable installer或32位3.5.2 Windows x86 executable installer)、(64位2 ...
    • 一、簡述 1.對象關係映射文件,用於映射實體類和關係資料庫數據表之間的一個 xml 文件。 2.通過 Entity.hbm.xml 映射文件,Hibernate 可以理解持久化類和數據表之間的對應關係,也可以理解持久化類屬性與數據表列之間的對應關係。 3.映射主鍵、映射關聯關係。 二、各個節點 說明 ...
    • Atitit.java c#.net php項目中的view復用(jsp,aspx,php的復用) 1.1. Keyword1 1.2. 前言1 2. Java項目使用。Net的aspx頁面view1 2.1. Aspx的顯示源碼解決之道1 2.2. Get path n param2 2.3. 還 ...
    • 每天一個設計模式-2 外觀模式(Facade) 1.生活中的示例 客戶想要購買一臺電腦,一般有兩種方法: 1.自己DIY,客戶需要知道組成電腦的所有電子器件,並且需要熟悉那些配件,對客戶要求較高。 2.去電腦組裝公司,告訴他們你需要的電腦配置,再由電腦組裝公司的人來組裝電腦,這種方式比較簡單通用,現 ...
    • 開本系列,談談一些有趣的 CSS 題目,題目類型天馬行空,想到什麼說什麼,不僅為了拓寬一下解決問題的思路,更涉及一些容易忽視的 CSS 細節。 解題不考慮相容性,題目天馬行空,想到什麼說什麼,如果解題中有你感覺到生僻的 CSS 屬性,趕緊去補習一下吧。 不斷更新,不斷更新,不斷更新,重要的事情說三遍 ...
    一周排行
      -Advertisement-
      Play Games
    • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
    • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
    • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
    • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
    • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
    • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
    • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
    • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
    • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
    • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...