私はknockout.jstemplatescriptを使用して、複製および削除できるフォームを作成しました。フィドルはここにあります。
SEのちょっとした助けを借りてスクリプトを編集し、jquery-uidatepickerを追加しました。フィドルの短いバージョンは[ここ][2]にあります。これまでのところ良好ですが、テストしたところ、IExplorer(さまざまなバージョン)を除いて、すべてがどのブラウザーでも機能することがわかりました。
問題はこの特定の部分にありますが、どこにあるのかわかりません。
script type='text/javascript'>//<![CDATA[
ko.bindingHandlers.datepicker = {
init: function (element, valueAccessor, allBindingsAccessor) {
var options = allBindingsAccessor().datepickerOptions || {};
console.log("datepicker");
$(element).datepicker(options);
//handle the field changing
ko.utils.registerEventHandler(element, "change", function () {
var observable = valueAccessor();
observable($(element).datepicker("getDate"));
});
//handle disposal (if KO removes by the template binding)
ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
$(element).datepicker("destroy");
});
}
};
また、今私たちはそれに取り組んでいます。ボックスの外側をクリックしても、日付ピッカーは閉じません。これはどのブラウザでも発生します。
追加の質問
私はこれ(および他の多くの)を使用してフィールドを自動修正します。この場合、入力は大文字になります。これは、最初のフォームでうまく機能します。ただし、重複するフォームではありません。
$( "。hoofdletters")。keyup(function(e){$( "。hoofdletters")。val(($( "。hoofdletters")。val())。toUpperCase());});
uniqueName:trueを使用すると、すべてのフィールド(重複したフォームも)が検証されます。しかし、私の$_POST名はすべて名前が変更されています。ko_unique_1の代わりにyear[]などの元のフィールド名が必要です。uniqueNameを削除すると機能しますが、複製されたフォームは検証されなくなります。
[2]: http: //jsfiddle.net/QUxyy/5/
enter code here