使用 jQuery 根据文本框的值动态显示图片

聖光之護
发布: 2025-10-17 10:51:11
原创
547人浏览过

使用 jquery 根据文本框的值动态显示图片

本文介绍如何使用 jQuery 实现一个图片画廊,根据文本框输入的值,动态地显示对应数量的图片。我们将从隐藏所有图片开始,然后根据用户在文本框中输入的数字,随机显示相应数量的图片。本文提供了两种实现方式,一种是顺序显示,另一种是随机显示,并附带完整的代码示例和注意事项。

准备工作

首先,确保你的 HTML 文件中引入了 jQuery 库和 Bootstrap 库(用于样式和模态框)。以下是需要引入的 CSS 和 JavaScript 文件:

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0/dist/css/bootstrap.min.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.13.2/themes/base/jquery-ui.min.css">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.9.0/jquery-ui.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0/dist/js/bootstrap.bundle.min.js"></script>
登录后复制

同时,你需要准备一些图片资源,并按照 images/1.png, images/2.png ... images/n.png 的格式命名,放置在 images 文件夹下。

HTML 结构

HTML 结构主要包含一个模态框(用于输入图片数量)和一个用于显示图片的容器。

<div class="container-fluid">
  <!-- 模态框 -->
  <div class="modal" id="myModal">
    <div class="modal-dialog">
      <div class="modal-content">
        <!-- 模态框头部 -->
        <div class="modal-header">
          <h4 class="modal-title">请输入图片数量</h4>
          <button type="button" class="close" data-dismiss="modal">&times;</button>
        </div>
        <!-- 模态框主体 -->
        <div class="modal-body">
          <div class="row">
            <div class="col-sm-5">
              <label>图片数量</label>
            </div>
            <div>
              <label>Drop Zones 数量</label>
            </div>
            <div class="col-sm-5">
              <input type="text" id='divimages' name="text" class="form-control input-sm numbers" />
            </div>
            <div class="col-sm-5">
              <input type="text" name="" id='dropZone' value="" class="form-control input-sm drpimg" />
            </div>
            <div class="col-sm-2 btn btn-primary btn-sm" id="clsSub">提交</div>
          </div>
        </div>
        <!-- 模态框底部 -->
        <div class="modal-footer">
          <button type="button" class="btn btn-danger" data-dismiss="modal">关闭</button>
        </div>
      </div>
    </div>
  </div>
  <!-- 模态框结束 -->

  <!-- 图片容器 -->
  <div class="container" style="border: 1px solid red; height: 250px; display: inline-flex;">
    <div class="row" id="gallery" style="width: 100%">
      @@##@@
      @@##@@
      @@##@@
      <!-- 更多图片... -->
      @@##@@
    </div>
  </div>
</div>
登录后复制

jQuery 代码实现 (顺序显示)

以下是使用 jQuery 实现顺序显示图片的代码。该代码首先隐藏所有图片,然后根据文本框的值,显示对应数量的图片。

$(function() {
  function showImages(int) {
    $("img[id^='no']").hide();
    $("img[id^='no']:lt(" + int + ")").show();
  }

  $('#myModal').modal('show');

  $("#clsSub").click(function() {
    var imgVal = parseInt($("#divimages").val());
    var drpVal = $("#dropZone").val();
    if (drpVal !== "" && imgVal <= 30) {
      showImages(imgVal);
      $('#myModal').modal('hide');
    }
  });
});
登录后复制

这段代码的关键在于 $("img[id^='no']:lt(" + int + ")").show(); 这行代码使用了 :lt() 选择器,它选择所有 id 以 no 开头的,且索引小于 int 的 img 元素,并将它们显示出来。

传媒公司模板(RTCMS)1.0
传媒公司模板(RTCMS)1.0

传媒企业网站系统使用热腾CMS(RTCMS),根据网站板块定制的栏目,如果修改栏目,需要修改模板相应的标签。站点内容均可在后台网站基本设置中添加。全站可生成HTML,安装默认动态浏览。并可以独立设置SEO标题、关键字、描述信息。源码包中带有少量测试数据,安装时可选择演示安装或全新安装。如果全新安装,后台内容充实后,首页才能完全显示出来。(全新安装后可以删除演示数据用到的图片,目录在https://

传媒公司模板(RTCMS)1.0 0
查看详情 传媒公司模板(RTCMS)1.0

jQuery 代码实现 (随机显示)

如果需要随机显示图片,可以使用以下代码:

$(function() {
  function showImages(int) {
    $("img[id^='no']").removeClass("show").addClass("hide");
    for (var i = 0; i < int; i++) {
      var n = Math.floor(Math.random() * $("img[id^='no']:not('.show')").length);
      console.log(i, n);
      $("img[id^='no']:not('.show')").eq(n).toggleClass("hide show");
    }
  }

  $('#myModal').modal('show');

  $("#clsSub").click(function() {
    var imgVal = parseInt($("#divimages").val());
    var drpVal = $("#dropZone").val();
    if (drpVal !== "" && imgVal <= 30) {
      showImages(imgVal);
      $('#myModal').modal('hide');
    }
  });
});
登录后复制

这段代码的关键在于:

  1. 首先,为所有图片添加 hide class,移除 show class。
  2. 然后,循环 int 次,每次循环随机选择一个当前未显示的图片,并切换其 hide 和 show class。

为了使代码生效,还需要添加以下 CSS 样式:

.hide {
  display: none;
}

.show {
  display: block;
}
登录后复制

完整代码示例 (随机显示)

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Dynamic Image Gallery</title>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0/dist/css/bootstrap.min.css">
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.13.2/themes/base/jquery-ui.min.css">
  <style>
    .imgC {
      width: 60px;
      height: 60px;
      margin-top: 5px;
    }

    .wth {
      height: 70px;
      padding: 10px;
      border: 1px solid #aaaaaa;
    }

    .hide {
      display: none;
    }

    .show {
      display: block;
    }
  </style>
</head>
<body>

<div class="container-fluid">
  <!-- The Modal -->
  <div class="modal" id="myModal">
    <div class="modal-dialog">
      <div class="modal-content">
        <!-- Modal Header -->
        <div class="modal-header">
          <h4 class="modal-title">Please Update the values</h4>
          <button type="button" class="close" data-dismiss="modal">&times;</button>
        </div>
        <!-- Modal body -->
        <div class="modal-body">
          <div class="row">
            <div class="col-sm-5">
              <label>Number of images</label>
            </div>
            <div>
              <label>number of drop Zones</label>
            </div>
            <div class="col-sm-5">
              <input type="text" id='divimages' name="text" class="form-control input-sm numbers" />
            </div>
            <div class="col-sm-5">
              <input type="text" name="" id='dropZone' value="" class="form-control input-sm drpimg" />
            </div>
            <div class="col-sm-2 btn btn-primary btn-sm" id="clsSub">Submit</div>
          </div>
        </div>
        <!-- Modal footer -->
        <div class="modal-footer">
          <button type="button" class="btn btn-danger" data-dismiss="modal">Close</button>
        </div>
      </div>
    </div>
  </div>
  <!-- modal close -->
  <!-- container end -->

  <div class="container" style="border: 1px solid red; height: 250px; display: inline-flex;">
    <div class="row" id="gallery" style="width: 100%">
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
      @@##@@
    </div>
  </div>
  <div>
  </div>
</div>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.9.0/jquery-ui.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0/dist/js/bootstrap.bundle.min.js"></script>
<script>
  $(function() {
    function showImages(int) {
      $("img[id^='no']").removeClass("show").addClass("hide");
      for (var i = 0; i < int; i++) {
        var n = Math.floor(Math.random() * $("img[id^='no']:not('.show')").length);
        console.log(i, n);
        $("img[id^='no']:not('.show')").eq(n).toggleClass("hide show");
      }
    }

    $('#myModal').modal('show');

    $("#clsSub").click(function() {
      var imgVal = parseInt($("#divimages").val());
      var drpVal = $("#dropZone").val();
      if (drpVal !== "" && imgVal <= 30) {
        showImages(imgVal);
        $('#myModal').modal('hide');
      }
    });
  });
</script>

</body>
</html>
登录后复制

注意事项

  • 确保图片资源存在且路径正确。
  • imgVal
  • 可以根据需要自定义 CSS 样式,调整图片的大小和布局。
  • 在实际应用中,应该对用户输入进行验证,防止输入非数字或超出范围的值。

总结

本文介绍了如何使用 jQuery 根据文本框的值动态显示图片。通过使用 :lt() 选择器或随机选择元素,可以轻松实现顺序显示或随机显示图片的功能。希望本文能帮助你理解和掌握 jQuery 的基本用法,并能应用到实际项目中。

使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片使用 jQuery 根据文本框的值动态显示图片

以上就是使用 jQuery 根据文本框的值动态显示图片的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号