我已经得到了下面的代码,代码没问题,唯一的问题是,如果我按顺序做了错误的事情,我想纠正它,整个文本被清除并开始从开始:按选项值订购商品
function getValues() {
var result = [];
var me = this;
$('select').each(function (idx, el) {
var $el = $(el);
result[3*$el.val()+idx]=($el.next('input[type="hidden"]').val() + ' ' + $el.val());
if (me === el) return false;
});
console.log(result);
$('#res').html(result.join(' '));
}
$('select.startID,input[type="hidden"]').change(getValues);
<select name="startID[]" class="startID">
<option value="0">SELECT</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<input type="hidden" name="startText[]" value="Text1">
Text1
<br />
<select name="startID[]" class="startID">
<option value="0">SELECT</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<input type="hidden" name="startText[]" value="Text2">
Text2
<br />
<select name="startID[]" class="startID">
<option value="0">SELECT</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<input type="hidden" name="startText[]" value="Text3">
Text3
<div id="res"></div>
DEMO:http://jsfiddle.net/aburayane/zwzx7ann/
所以在选择框前面的文本是在隐藏的输入一样,我应该从选择框,对应于文字前面相同的值,例如1 => Text1,2 => Text2,3 => Text3,如果错误地选择了1 => Text2,2 => Text1和3 => Text3,所以我的错误出现在Text1和Text2中,我没有选择正确的值,如果我想纠正,整个文本被删除并从头开始。
我的问题:有没有什么方法可以在不删除数据的情况下对打印的文本进行更正,它应该交换在一起。
在此先感谢
上面的例子是由文本排序的不是值 – 2014-09-01 12:04:56
你是什么意思?我的代码片段旨在解决您的基本需求*“更正打印的文本而不擦除数据”*。不知道你在这里指的是什么。 – tmarwen 2014-09-01 12:24:09
没有数据被删除,但订单被搞乱 – 2014-09-01 12:54:13