0
KnockoutJS를 처음 사용합니다. 페이지는이 자료 구조는 작은 조각으로 갈라진다 및 데이터의 이러한 덩어리 구성 요소에 전달되는 KnockoutJS 구성 요소에서 업데이트 된 데이터 어셈블하기
- : 나는 다음과 같은 방식으로 작동하는 응용 프로그램을 가지고
- 사용자는
내가 가지고있는 백엔드에 전달해야한다 버튼 업데이트 복잡한 데이터 구조를 클릭시 데이터
이 조각에서 같은 코드입니다. 내가 뭘 시도했는지에 대한 질문 하단을 보라.
ko.components.register('firstComponent', {
viewModel: function(params) {
var self = this;
self.firstComponentValue = ko.observable(params.firstComponentValue);
},
template: '<div><pre data-bind="text: JSON.stringify(ko.toJS($data), null, 2)"></pre><input data-bind="value: firstComponentValue, valueUpdate: \'afterkeydown\'"></div>'
});
ko.components.register('secondComponent', {
viewModel: function(params) {
var self = this;
self.secondComponentValue = ko.observable(params.secondComponentValue);
},
template: '<div><pre data-bind="text: JSON.stringify(ko.toJS($data), null, 2)"></pre><input data-bind="value: secondComponentValue, valueUpdate: \'afterkeydown\'"></div>'
});
var json = '{"items":[{"componentName":"firstComponent","firstComponentValue":"somevalue"},{"componentName":"secondComponent","secondComponentValue":"someothervalue"}]}';
var data = JSON.parse(json);
var mainVM = {};
mainVM.items = ko.observableArray(
ko.utils.arrayMap(data.items,
function(item) {
return ko.observable(item);
}));
ko.applyBindings(mainVM);
$('input[type=button]').click(function() {
var updatedData = ko.dataFor(document.getElementById('main'));
//get updated json somehow?
console.log(data);
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="main">
<pre data-bind="text: JSON.stringify(ko.toJS($data), null, 2)"></pre>
<div data-bind="foreach: {data: items, as: 'item'}">
<hr>
<div data-bind="component: {name:componentName, params: item}">
</div>
</div>
<hr>
<input type="button" value="post data">
</div>
ko.dataFor($("#rootElement"))
을 사용하고 백엔드에 보낼 수 있었던 하나의 뷰 모델이 있다면. 그러나 구성 요소를 사용하려고하며 루트 뷰 모델에 연결되지 않은 자체 뷰 모델을 사용합니다. 나는 jQuery로 그들을 모두 찾을 수 있었고 ko.dataFor
을 사용했지만 큰 해킹처럼 보였다. 메인 뷰 모델의 구성 요소를 포함하여 모든 뷰 모델을 정의 할 수도 있지만 구성 요소를 쓸모 없게 만듭니다. 또한 구성 요소 viewmodels 생성자를 변경하여 입력 데이터를 변경하고 관찰 할 수없는 값을 재정의하려고 시도했지만 나에게도 해킹처럼 보입니다.
ko.components
과 같은 기능이 있습니까? 아니면 모든 살아있는 뷰 모델을 제공 할 수 있습니까?