Код:
<tr> |
Nicson,
Ну это не то, чтобы неправильно, скорее, это выглядит как: вам надо положить пару швов на руку, но лучше отрубить руку и новую на её место пришить. Как-то так) |
Согласен, но по другому пока не знаю как это сделать. На первый вариант, думаю пойдет. Потом может разберусь и сделаю как надо
|
Давайте так, я пишу на JQ и тоже с учетом динамического добавления полей, а если надо, то и удаления. Просто если надо удалить, а не потому, что в поле замечена ошибка, для исправления ошибки не надо удалять поле.
То что мы "работаем" с полем текущим в примере будет отражаться отображением его значения на странице. Не было ответа на вопрос по номеру i, и я предполагая удаляю его, ибо просто нумерация полей будет соблюдена и так. Номер может потребоваться только в том случае, если поля (именно поля как набора значений) нужно привязать например к некоторому идентификатору. То есть "работать" будет то поле, которое имеет фокус - запрос сервера за каталожным номером. Вернуться для изменения в любое из полей тоже не проблема. Удалить поле, так же пожалуйста. Отправка формы отобразит отправляемые данные, сервер при это получить элементы массива abc начиная с индекса 0. <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script> <script> $(function() { $('#add').click(function() { $('#fields').append('<div><input name="abc[key][][field]"> <span id="del">Del</span></div>') }); $('#fields').on('keyup', 'input', function() { $('#val').text(this.value) }).on('click', 'span', function() { $(this).parent().remove() }); $('form').submit(function(e) { e.preventDefault(); $('#val').text(JSON.stringify($(this).serializeArray())) }) }); </script> </head> <body> <span id="add">Add</span> <form> <div id="fields"></div> <button>Send</button> </form> </body> <div id="val"></div> </html> То есть проблемы как таковой и нет собственно говоря, но с другой стороны много неясностей. Цитата:
Еще раз - поле должно иметь имя и только затем ключи его, иначе сервер не примет таковых данных. PS. data[Application][<%= key %>][num_app] - вот это другой разговор. Имя поля, это "data", а далее это ключи. Если key, это идентификатор (только в этом случае можно говорить об уникальности), которому значения полей будут добавлены, тогда да, это нужно, и это не просто число как вы писали. В противном случае это число указывать не обязательно. Полей несколько, а значит добавляется не поле, а группа полей, так? |
Цитата:
|
Цитата:
|
Цитата:
|
Я вам не предлагаю отказываться от движка, и код этого не предполагает. Вы не даете пояснений. Что такое есть <%= key %>?
В JS коде примера, собственно говоря, наплевать будет там номер или нет, если это просто номер. Пример с чего начинается? Правильно, нет вообще полей. А если ваш движок по умолчан6ию пусть помещает в форму одно поле, а остальные добавляет пользователь, и надо нумеровать, ну так ведь не проблема считать вставки и удаления, и вставляя некий номер. Другое дело, если <%= key %>, это уникальный идентификатор, то не проблема его сообщить клиенту, или получить из имени, так как он постоянен будет. |
ок, если хотите, я могу выложить код PHP фреймворка этого, как это все работает. Но там без пояснений не понятно. Сам с этим разбирался долго по статье из инета. Но сайт сейчас почему то не работает этот.
|
Цитата:
Этот форум по вопросам клиентского скрипта, РНР может затрагиваться в неких случаях, но только кратко, для уяснения причины к примеру. А выложить код фреймворка, это слишком, смотреть его не будут. Вы и без этого кода должны знать что это за число, вы же задачу ставите, код движка лишь решает ее. Косвенно понять это также не сложно, посмотрев результирующий html-код формы на странице. |
Часовой пояс GMT +3, время: 22:27. |