Ich habe ein Problem mit Daten * Attributen in knockout.js dh. schreibe sie mit attr
aus.
Ich kann das ohne Probleme machen:
<input data-bind='text: Title, attr: {name: "Events[" + viewModel.events.indexOf($data) + "].Title"}'/>
wenn ich jedoch data-id
verwenden möchte, funktioniert der reguläre Weg nicht. Deshalb füge ich das Attribut in ein einzelnes Zitat ein:
<input data-bind='text: Title, attr: {'data-id': "Events[" + viewModel.events.indexOf($data) + "].Title"}'/>
was gibt mir
Error: Unable to parse bindings.
Message: SyntaxError: missing } in compound statement;
Bindings value: attr: {
http://127.0.0.1:21254/Scripts/knockout/knockout-2.2.0.js
kann jemand sehen, was hier schief gelaufen ist?
Prost!
Sie müssen nur doppelte Anführungszeichen setzen:
<input data-bind='text: Title, attr: {"data-id": "Events[" + viewModel.events.indexOf($data) + "].Title"}'/>
Nachfolgend finden Sie einen Funktionsausschnitt, der veranschaulicht, wie ein benutzerdefinierter Datenattributwert mit Knockout festgelegt wird:
ko.applyBindings({
somevalue: 'foo',
title: 'Knockout custom data attribute binding -- example'
});
$("#result").text($("#test-el").data("someattr"));
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<div data-bind="text: title, attr: {'data-someattr': somevalue}" id="test-el"></div>
<p>
<b>Test data attribute expected value:</b> foo
</p>
<p>
<b>Test data attribute value: </b>
<span id="result"></span>
</p>
Sie müssen nicht einmal doppelte oder einfache Anführungszeichen um den Namen von attr setzen, gehen Sie einfach mit data-id
<input data-bind='text: Title, attr: {data-id: "Events[" + viewModel.events.indexOf($data) + "].Title"}'/>