Используя jquery clone(), новый класс загрузочного Tokenfield генерирует в поле ввода
Идти к
http://jsfiddle.net/rns3hang/450/
TokenField во вновь клонированном поле ввода работает, но проблема в том, что он находится внутри поля ввода
И я хочу только одно поле ввода с некоторыми предопределенными / постоянными тегами и иметь возможность добавлять новые токены или значения тегов, а также
<body>
<br /><br />
<div class="container">
<br />
<h2 align="center"> Insert Diet</h2>
<br /><table class="table table-bordered" >
</table>
<br>
<div class="table-responsive">
<table class="table table-bordered" id="crud_table">
<tr>
<th width="20%">Breakfast</th>
<th width="20%">Pre Lunch</th>
<th width="20%">Lunch</th>
<th width="5%"></th>
</tr>
<tr class="tableinputs">
`
<td><input type="text" class="break_name skill" value="Tea/Coffee"/></td>
<td ><input type="text" class="mid_meal skill" value="Fruits"/></td>
<td ><input type="text" class="lunch_name skill" value="Vegetables,salads"/></td>
<td><button type='button' name='remove' data-row='row"+count+"' class='btn btn-danger btn-xs remove'>-</button></td>
</tr>
</table>
<div align="right">
<button type="button" name="add" id="add" class="btn btn-success btn-xs">Add</button>
</div>
<div align="center">
<button type="button" name="save" id="save" class="btn btn-info">Save</button>
</div>
<br />
</div>
</div>
</body>
Код Jquery
$(document).ready(function(){
$('.skill').tokenfield({
autocomplete:{
source: ['Food1','Food2','Food3','Food4','Food5','CSS','Laravel','CakePHP'],
delay:100
},
showAutocompleteOnFocus: true
});
var count = 1;
var $table;
$table=$('#crud_table tbody');
var $existRow=$table.find('tr').eq(1);
/* bind to existing elements on page load*/
bindAutoComplete($existRow);
$('#add').click(function(){
//$("#crud_table tbody tr.tableinputs:last").clone().appendTo("#crud_table tbody");
var $row=$("#crud_table tbody tr.tableinputs:last").clone();
var $input=$row.find(":text").val("");
$table.append($row);
/*
$(".break_name:last").val('');
$(".mid_meal:last").val('');
$(".lunch_name:last").val('');*/
bindAutoComplete($row );
$input.focus();
});
function bindAutoComplete($row ){
/* use row as main element to save traversing back up from input*/
$row.find('.skill').tokenfield({
autocomplete:{
source: ['Food1','Food2','Food3','Food4','Food5','CSS','Laravel','CakePHP'],
delay:100
},
showAutocompleteOnFocus: true
});
$('.skill').on('tokenfield:createtoken', function (event) {
var existingTokens = $(this).tokenfield('getTokens');
$.each(existingTokens, function(index, token) {
if (token.value === event.attrs.value)
event.preventDefault();
});
});
}
$(document).on('click', '.remove', function(){
//If this there is only one row left clear that row instead of removing it
if ($("#crud_table tbody tr").length === 1)
$("#crud_table tbody tr:last").find("input").val('');
else
$("#crud_table tbody tr:last").remove();
});
});
Я попытался удалить атрибут значения из поля ввода, но он все еще не работает
1 ответ
И я хочу только одно поле ввода
Это немного сложно из-за логики, которую использует bootstrap-tokenfield. Но у меня есть возможное решение, которое может вас порадовать. Мы уважаем созданные новые поля ввода, но удаляем атрибут "имя", поэтому он игнорируется формой.
до:
$('.skill').on('tokenfield:createtoken', function (event) {
var existingTokens = $(this).tokenfield('getTokens');
$.each(existingTokens, function(index, token) {
if (token.value === event.attrs.value)
event.preventDefault();
});
});
после
$('.skill').on('tokenfield:createtoken', function (event) {
var existingTokens = $(this).tokenfield('getTokens');
$.each(existingTokens, function(index, token) {
if (token.value === event.attrs.value)
event.preventDefault();
});
$(this).data('bs.tokenfield').$input.attr("name",""); //<- this is the new line
});