使用 jQuery 获取相关的 Div 文本
Obtain Related Div Text with jQuery
经过一些努力和一些有价值的建议,我找到了一个行之有效的解决方案
如下:
$(document).ready(function(){
divs = $(".divs").children();
divs.each(function(e) {
if (e != 0)
$(this).hide();
});
$("#next").click(function(){
if (divs.next().length != 0)
divs.next().show().prev().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$("#prev").click(function(){
if (divs.prev().length != 0)
divs.prev().show().next().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$(".btn").click(function() {
$('.cbCheck:checkbox:checked').each(function(){
var id = $(".h2Val").text();
alert(id + $(this).val());
});
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="divs">
<div class="heading">
<div class="h2Val">
1
</div>
<div>What's the capital of England?</div>
<div class="heading2">
<div>
<input type="checkbox" id="val1" class="cbCheck" name="val1" value="London" />London</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val2" class="cbCheck" name="val2" value="New York" />New York</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
<div class="heading">
<div class="h2Val">
2
</div>
<div>Who invented computer?</div>
<div class="heading2">
<div><input type="checkbox" id="val3" class="cbCheck" name="val3" value="Thomas Edison" />Thomas Edison</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val4" class="cbCheck" name="val4" value="Charles Babbage" />Charles Babbage</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val5" class="cbCheck" name="val5" value="Sir Isaac Newton" />Sir Isaac Newton</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
</div>
<a id="prev">Previous</a>
<a id="next">Next</a>
如您所见,我展示了一些带有选项的问题 selected。与之前和
下一步按钮,我可以看到上一个或下一个问题和 select 答案。我的挑战是什么时候
我 select 一个 CheckBox,在 div 中说 class h2Val,我需要得到各自的号码
其中 div.
1
Ques: What's the capital of England?
Options:
i) London
ii) New York
假设我select编辑了伦敦,当点击获取价值按钮时,它应该会显示selected
值以及顶部的数字 1 和问题 2 相同。我尝试了这个,但它让我得到了 div:
中的所有数字
$('.cbCheck:checkbox:checked').each(function(){
var id = $(".h2Val").text(); //Trying to obtain the div text
alert(id + $(this).val());
});
我在这里错过了什么吗?任何想法将不胜感激 - 谢谢。
$(".h2Val").text()
从选择器中的所有匹配元素获取所有文本。
您需要将实例定位在与按钮相同的 .heading
容器中。
使用 closest()
遍历主父容器并使用 find()
仅在该实例中查找
$(document).ready(function() {
divs = $(".divs").children();
divs.each(function(e) {
if (e != 0)
$(this).hide();
});
$("#next").click(function() {
if (divs.next().length != 0)
divs.next().show().prev().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$("#prev").click(function() {
if (divs.prev().length != 0)
divs.prev().show().next().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$(".btn").click(function() {
var $container = $(this).closest('.heading')
var id = $container.find(".h2Val").text().trim();
var $checked = $container.find('.cbCheck:checked');
var values = $checked.map(function(){
return this.value
}).get();
console.clear()
console.log('ID: ' + id +' has ' + $checked.length + ' checked');
console.log('Values: ', values.join())
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="divs">
<div class="heading">
<div class="h2Val">
1
</div>
<div>What's the capital of England?</div>
<div class="heading2">
<div>
<input type="checkbox" id="val1" class="cbCheck" name="val1" value="London" />London</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val2" class="cbCheck" name="val2" value="New York" />New York</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
<div class="heading">
<div class="h2Val">
2
</div>
<div>Who invented computer?</div>
<div class="heading2">
<div><input type="checkbox" id="val3" class="cbCheck" name="val3" value="Thomas Edison" />Thomas Edison</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val4" class="cbCheck" name="val4" value="Charles Babbage" />Charles Babbage</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val5" class="cbCheck" name="val5" value="Sir Isaac Newton" />Sir Isaac Newton</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
</div>
<a id="prev">Previous</a>
<a id="next">Next</a>
经过一些努力和一些有价值的建议,我找到了一个行之有效的解决方案 如下:
$(document).ready(function(){
divs = $(".divs").children();
divs.each(function(e) {
if (e != 0)
$(this).hide();
});
$("#next").click(function(){
if (divs.next().length != 0)
divs.next().show().prev().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$("#prev").click(function(){
if (divs.prev().length != 0)
divs.prev().show().next().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$(".btn").click(function() {
$('.cbCheck:checkbox:checked').each(function(){
var id = $(".h2Val").text();
alert(id + $(this).val());
});
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="divs">
<div class="heading">
<div class="h2Val">
1
</div>
<div>What's the capital of England?</div>
<div class="heading2">
<div>
<input type="checkbox" id="val1" class="cbCheck" name="val1" value="London" />London</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val2" class="cbCheck" name="val2" value="New York" />New York</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
<div class="heading">
<div class="h2Val">
2
</div>
<div>Who invented computer?</div>
<div class="heading2">
<div><input type="checkbox" id="val3" class="cbCheck" name="val3" value="Thomas Edison" />Thomas Edison</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val4" class="cbCheck" name="val4" value="Charles Babbage" />Charles Babbage</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val5" class="cbCheck" name="val5" value="Sir Isaac Newton" />Sir Isaac Newton</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
</div>
<a id="prev">Previous</a>
<a id="next">Next</a>
如您所见,我展示了一些带有选项的问题 selected。与之前和 下一步按钮,我可以看到上一个或下一个问题和 select 答案。我的挑战是什么时候 我 select 一个 CheckBox,在 div 中说 class h2Val,我需要得到各自的号码 其中 div.
1
Ques: What's the capital of England?
Options:
i) London
ii) New York
假设我select编辑了伦敦,当点击获取价值按钮时,它应该会显示selected 值以及顶部的数字 1 和问题 2 相同。我尝试了这个,但它让我得到了 div:
中的所有数字$('.cbCheck:checkbox:checked').each(function(){
var id = $(".h2Val").text(); //Trying to obtain the div text
alert(id + $(this).val());
});
我在这里错过了什么吗?任何想法将不胜感激 - 谢谢。
$(".h2Val").text()
从选择器中的所有匹配元素获取所有文本。
您需要将实例定位在与按钮相同的 .heading
容器中。
使用 closest()
遍历主父容器并使用 find()
仅在该实例中查找
$(document).ready(function() {
divs = $(".divs").children();
divs.each(function(e) {
if (e != 0)
$(this).hide();
});
$("#next").click(function() {
if (divs.next().length != 0)
divs.next().show().prev().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$("#prev").click(function() {
if (divs.prev().length != 0)
divs.prev().show().next().hide();
else {
divs.hide();
divs.show();
}
return false;
});
$(".btn").click(function() {
var $container = $(this).closest('.heading')
var id = $container.find(".h2Val").text().trim();
var $checked = $container.find('.cbCheck:checked');
var values = $checked.map(function(){
return this.value
}).get();
console.clear()
console.log('ID: ' + id +' has ' + $checked.length + ' checked');
console.log('Values: ', values.join())
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="divs">
<div class="heading">
<div class="h2Val">
1
</div>
<div>What's the capital of England?</div>
<div class="heading2">
<div>
<input type="checkbox" id="val1" class="cbCheck" name="val1" value="London" />London</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val2" class="cbCheck" name="val2" value="New York" />New York</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
<div class="heading">
<div class="h2Val">
2
</div>
<div>Who invented computer?</div>
<div class="heading2">
<div><input type="checkbox" id="val3" class="cbCheck" name="val3" value="Thomas Edison" />Thomas Edison</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val4" class="cbCheck" name="val4" value="Charles Babbage" />Charles Babbage</div>
</div>
<div class="heading2">
<div><input type="checkbox" id="val5" class="cbCheck" name="val5" value="Sir Isaac Newton" />Sir Isaac Newton</div>
</div>
<div>
<input type="button" class="btn" value="Get Value" />
</div>
</div>
</div>
<a id="prev">Previous</a>
<a id="next">Next</a>