我试图创建一种用户输入计算方法,其中输入字段和计算公式是动态设置的。例如,有一个苹果数和一个苹果输入的价格,所以我乘以输入来得到价格。在另一种情况下,我有长度,宽度和高度输入来计算体积。
我决定存储输入、数据和计算函数,并使用羊驼重新组装json表单。
但是,计算字段只是更大形式的一部分。所以用
$("#alpacaForm").alpaca(window.alpacaForm.object);在alpacaForm元素中添加新窗体。
是否有一种将羊驼生成的字段附加到现有表单中的方法?
发布于 2017-05-09 18:25:23
我成功地做到这一点的唯一方法是将元素呈现到一个单独的元素中,并复制这些元素。
例如:
<form id="my-form">
<!-- My controls: -->
<label for="foo">Foo</label>
<input id="foo">
<label for="bar">Bar</label>
<input id="bar">
<!-- I want the schema-based controls to go into this div. -->
<div class="schema-control-container"></div>
</form>JavaScript (和jQuery):
var $myForm = $('#my-form');
var $schemaControlContainer = $myForm.find('.schema-control-container');
var mySchema = JSON.parse(mySchemaJson);
var $scratchpad = $('<div id="alpacaScratchpad"></div>').hide().
insertAfter($myForm);
function postRender (control) {
// I actually have multiple forms, so I need to make sure the IDs are unique.
$scratchpad.find('.alpaca-control').each(function (i, alpacaControl) {
alpacaControl.id = $myForm.attr('id') + '-' + alpacaControl.id;
});
$scratchpad.find('.alpaca-control-label').each(
function (i, alpacaControlLabel) {
alpacaControlLabel.htmlFor = $myForm.attr('id') + '-' +
alpacaControlLabel.htmlFor;
});
// Select elements we want to copy. Note that I haven't tried this with any
// particularly complicated JSON schemata, so this may be naïve.
var $goodies = $scratchpad.find('.alpaca-control,.alpaca-control-label');
// Optional: mark schema controls as such, and allow autocompletion.
$goodies.filter('.alpaca-control').addClass('my-schema-datum').
attr('autocomplete', null);
// Remove Alpaca classes and Bootstrap crap. (I hate Bootstrap, but the 'web'
// version of Alpaca doesn't seem to work right now. TODO: Update after
// https://github.com/gitana/alpaca/issues/507 is fixed.)
$goodies.removeClass('alpaca-control').removeClass('alpaca-control-label').
removeClass('form-control').removeClass('control-label');
// Move the goodies to the schema control container, in the form.
$schemaControlContainer.append($goodies);
// Clean up the clutter we don't need.
$scratchpad.empty();
}
// Have Alpaca render the schema into the scratchpad, and then run the function
// we just defined.
$scratchpad.alpaca({ schema: mySchema, postRender: postRender });我本来希望能找到一个羊驼选项来避免这一切的发生,但似乎没有。
https://stackoverflow.com/questions/42767045
复制相似问题