jquery获取先前输入的文本值
jquery get previous input text value
我的表单中有以下html:
<div>
<input type="text" style="margin-top: 10px; float: none;" class="validate[required] span3 m-wrap answopts answerdets" placeholder="Answer Options" id="answersweroptions" name="answersweroptions[0]">
<img class="removeanswer" style="width: 50px; margin-top: 9px;" src="../images/remove.png">
</div>
<p class="disoptinputs">
<input type="radio" style="margin:-85px 0 0 !important;" class="validate[required] coranschk" id="questionoption" name="questionoption[0][]">
</p>
<div>
<input type="text" style="margin-top: 10px; float: none;" class="validate[required] span3 m-wrap answopts answerdets0" placeholder="Answer Options" id="answersweroptions1" name="answersweroptions[0][]">
<img id="1" class="removeanswer" style="width: 50px; margin-top: 9px;" src="../images/remove.png"></div>
<p class="disoptinputs0">
<input type="radio" class="coranschk validate[required]" cntr="7" atrid="0" id="questionoption7" name="questionoption[0][]">
</p>
<div>
<input type="text" style="margin-top: 10px; float: none;" class="validate[required] span3 m-wrap answopts answerdets0" placeholder="Answer Options" id="answersweroptions2" name="answersweroptions[0][]">
<img id="2" class="removeanswer" style="width: 50px; margin-top: 9px;" src="../images/remove.png">
</div>
<p class="disoptinputs0">
<input type="radio" class="coranschk validate[required]" cntr="7" atrid="0" id="questionoption7" name="questionoption[0][]">
</p>
这个div和p标记是多个。现在,我想要的是,当用户点击任何单选按钮时,我想要div中单选按钮之前的输入框的值。我试过这个$(this).prev().prve().val(),但它不起作用。任何帮助都将不胜感激。提前感谢。
您可以使用.closest()
或.parent()
首先选择单击的radio
的父级,然后使用.prev()
定位div
。您还需要使用.find()
来定位input
元素。
$(this).closest('.disoptinputs').prev().find('input').val();
注意:由于有多个输入元素,您不需要id
,因为它们应该是唯一的。
更新
如果p
元素没有公共类,则此代码将不起作用。在这种情况下,您必须将.disoptinputs
替换为p
,如下面的演示所示。
$(function() {
$('p > :radio').on('change', function() {
var ival = $(this).closest('p').prev().find('input').val();
alert( ival );
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
<input type="text" style="margin-top: 10px; float: none;" class="validate[required] span3 m-wrap answopts answerdets0" placeholder="Answer Options" id="answersweroptions2" name="answersweroptions[0][]">
<img id="2" class="removeanswer" style="width: 50px; margin-top: 9px;" src="../images/remove.png">
</div>
<p class="disoptinputs0">
<input type="radio" class="coranschk validate[required]" cntr="7" atrid="0" id="questionoption7" name="questionoption[0][]">
</p>
尝试:
$(this).parent().prev().find('input').val()
正如您所说,您有多个类似的div和p标记元素,这会导致单选按钮和输入的id重复。ID必须是唯一的。你们可以使用相同的类。
对于遍历,您可以遍历到最近的p标记,然后遍历到它的上一个同级div,并在其中找到元素:
$('.disoptinputs :radio').click(function(){
var previnp = $(this).closest('.disoptinputs').prev().find('input').val();
});
$('input[type="radio"]').click(function() {
var getPrevText = $(this).parent().prev().find("input[type=text]:first").val();
alert(getPrevText); //returns with the prev Val
});
尝试上面的代码,看看它的工作:)
CCD_ 12到目标电流元件。(单选按钮)
parent()
到目标当前元素的父元素(此处为p标签)
prev()
以p标签(div)的前一个元素为目标
find("input[type=text]")
到前一个div 内的目标输入标签
相关文章:
- 让文本输入幻灯片显示输入时的新文本输入?然后向后滑动
- Sails.js:同时发布文本输入和一个文件
- 来自文本输入null的html javascript变量
- 当没有文本输入聚焦时检测空格键按下
- JS中的按钮和文本输入
- JavaScript:在调用函数的文本输入上按enter键
- jQuery自动完成功能不适用于多个文本输入
- 使用JS从选择和文本输入中捕获值,并将输出返回到HTML
- 如何通过jQuery发送选定的元素和文本输入
- HTML如何根据javascript函数的返回值限制文本输入
- jquery插件或javascript方法自动调整文本输入(而非文本区域)(固定宽度)可变高度的大小
- 在jquery中获取文本输入val始终为空
- HTML文本输入大小
- 文本输入与文本区域
- 角度ui选择标记模糊时丢失文本输入
- 文本输入值中的JavaScript变量
- Angular指令中的最佳实践是将文本输入设置为英尺和英寸的格式
- 如何在不通过模型验证的情况下屏蔽文本输入中输入的字符
- 在文本输入区域中创建双向更新
- 不使用自定义CSS或HTML(使用框架方法)的角度材质文本输入或文本区域标签大小