我的结构就像每张图片都有下面的输入。我在屏幕上有x图像。每个图像都有onlick选项
onclick="imageClicked(this)"
功能创建图像边框并显示折叠输入。图像的边框正在显示,但输入不是可见的。
这是功能
function imageClicked(image) {
var input = $(image).closest("input");
$(image).css('outline', "solid 2px #5bc0de");
$(input).css("visibility", "visible");
$(input).focus();
$(input).focusout(function () {
$(image).css('outline', "0");
if ($(input).val() === "0") {
$(input).css("visibility", "collapse");
}
});
$(image).focusout(function () {
if ($(input).val() === "") {
$(image).css('outline', "0");
}
});
}
这是Razor View中的HTML结构
@for (int i = 0; i < Model.Boxes.Count; i++){
var base64 = Convert.ToBase64String(Model.Boxes[i].Photo);
var imgSrc = String.Format("data:image/gif;base64,{0}", base64);
var imageId = Model.Boxes[i].BoxId;
@Html.HiddenFor(m => m.Boxes[i].BoxId)
<div class="col-md-2">
<img src="@imgSrc" width="50%" alt="@Model.Boxes[i].Name" id="@string.Format("image{0}", imageId)" onclick="imageClicked(this)" />
@Html.TextBoxFor(m => m.Boxes[i].Quantity, new { @class = "form-control", @style = "visibility: collapse; width: 50%; margin-top: 1%", @id = string.Format("input{0}", imageId) })
</div>
}
答案 0 :(得分:3)
最近将搜索父元素。这里的输入不是图像的父元素。它只是一个兄弟姐妹。您可以使用siblings()选择器来实现此目的。
var input = $(image).siblings("input");
或者你可以使用,
var input = $(image).closest(".col-md-2").find("input");