在文本框内设置同心圆

在文本框内设置同心圆

本文档旨在指导开发者如何在HTML文本框内创建和控制同心圆,并解决输入值改变后圆圈大小不更新的问题。通过修改CSS的定位方式,将圆圈定位在文本框内,并使用JavaScript动态调整圆圈大小。同时,本文档还提供了一种限制输入值大小,并向用户显示错误提示的方法,确保圆圈不会超出屏幕范围。

1. HTML 结构

首先,我们需要一个包含标题、输入框和用于绘制圆圈的容器的HTML结构。

Cutter Calculator



2. CSS 样式

关键在于.circles容器的定位方式和圆圈的定位方式。我们需要将.circles设置为position: relative,而将.circle和.circle2设置为position: absolute。 这样,圆圈就会相对于.circles容器进行定位,而不是整个页面。

.wrapper {  height: 400px;  width: 100%;  display: flex;  align-items: center;  justify-content: center;  flex-direction: column;}.circles {  margin-top: 15px;  position: relative;}.circle {  display: inline-block;  border-radius: 50%;  border-style: solid;  border-width: 2px;  border-color: blue;  background-color: rgba(0, 0, 0, 0);  z-index: -1;  left: 50%;  top: 50%;  position: absolute;}.circle2 {  display: inline-block;  position: absolute;  border-radius: 50%;  border-style: solid;  border-width: 2px;  border-color: red;  background-color: rgba(0, 0, 0, 0);  z-index: -1;  left: 50%;  top: 50%;}

3. JavaScript 代码

使用jQuery监听输入框的change事件,当输入值改变时,动态调整圆圈的大小。同时,我们还需要动态调整.circles容器的大小,以适应圆圈的大小。

$(function() {  $('.circle').hide();  $('#outer_diameter').on('change', function() {    var $outer_diameter = parseFloat($("#outer_diameter").val()).toFixed(3);    var $converted = ($outer_diameter * 10).toFixed(3);    console.log($outer_diameter, $converted);    $('.circle').css({      height: (2 * $converted),      width: (2 * $converted),      top: "calc(50% - " + ($converted) + "px)",      left: "calc(50% - " + ($converted) + "px)"    });    $('.circle').fadeIn(300);    $('.circles').css({height:(2 * $converted) + 10, width: (2 * $converted) + 10})    $('#error').hide();  })  $('.circle2').hide();  $('#inner_diameter').on('change', function() {    var $outer_diameter = parseFloat($("#outer_diameter").val()).toFixed(3);    var $inner_diameter = parseFloat($("#inner_diameter").val()).toFixed(3);    var $converted_2 = (($outer_diameter * 10) - ($inner_diameter * 10)).toFixed(3);    console.log($inner_diameter, $converted_2);    $('.circle2').css({      height: (2 * $converted_2),      width: (2 * $converted_2),      top: "calc(50% - " + ($converted_2) + "px)",      left: "calc(50% - " + ($converted_2) + "px)"    });    $('.circle2').fadeIn(300);  })});

代码解释:

$(‘.circle’).hide();: 页面加载时隐藏圆圈。$(‘#outer_diameter’).on(‘change’, function() { … });: 监听outer_diameter输入框的change事件。当输入框的值发生改变时,执行回调函数。parseFloat($(“#outer_diameter”).val()).toFixed(3);: 获取输入框的值,转换为浮点数,并保留三位小数。$(‘.circle’).css({ … });: 设置.circle元素的CSS属性,包括高度、宽度、top和left。$(‘.circle’).fadeIn(300);: 以300毫秒的淡入效果显示.circle元素。$(‘.circles’).css({height:(2 * $converted) + 10, width: (2 * $converted) + 10}): 设置包含圆圈的容器的高度和宽度,保证容器能够包含住圆圈。$(‘#inner_diameter’).on(‘change’, function() { … });: 监听inner_diameter输入框的change事件,逻辑与outer_diameter类似。

4. 限制输入值大小

为了防止用户输入过大的值导致圆圈超出屏幕范围,我们可以添加一个条件判断,限制输入值的范围。

$('#outer_diameter').on('change', function() {  var $outer_diameter = parseFloat($("#outer_diameter").val()).toFixed(3);  if ($outer_diameter >= 85) {    alert("Outer Diameter Too big");    // 或者显示一个错误信息    // $('#error').text("Outer Diameter Too big").show();    return;  }  var $converted = ($outer_diameter * 10).toFixed(3);  console.log($outer_diameter, $converted);  $('.circle').css({    height: (2 * $converted),    width: (2 * $converted),    top: "calc(50% - " + ($converted) + "px)",    left: "calc(50% - " + ($converted) + "px)"  });  $('.circle').fadeIn(300);  $('.circles').css({height:(2 * $converted) + 10, width: (2 * $converted) + 10})  $('#error').hide();})

代码解释:

if ($outer_diameter >= 85) { … }: 如果输入值大于等于85,则显示一个警告框,并阻止后续代码的执行。alert(“Outer Diameter Too big”);: 显示一个警告框,提示用户输入的值过大。return;: 阻止后续代码的执行。

5. 解决Formidable Forms计算后圆圈大小不更新的问题

如果使用了Formidable Forms,并且计算后的值没有立即更新圆圈的大小,可能是因为Formidable Forms的计算过程没有触发change事件。 我们需要手动触发change事件,或者直接在Formidable Forms的回调函数中更新圆圈的大小。

方法一:手动触发change事件

在Formidable Forms的计算完成后,手动触发outer_diameter和inner_diameter输入框的change事件。

// 假设Formidable Forms计算完成后会执行这个函数function formidableFormsCalculationComplete() {  $('#outer_diameter').trigger('change');  $('#inner_diameter').trigger('change');}

方法二:在Formidable Forms的回调函数中更新圆圈大小

找到Formidable Forms的计算完成后的回调函数,直接在回调函数中更新圆圈的大小。 这需要你熟悉Formidable Forms的API和事件机制。

总结:

通过以上步骤,我们可以在文本框内创建和控制同心圆,并解决输入值改变后圆圈大小不更新的问题。关键在于CSS的定位方式和JavaScript的动态调整。同时,我们还提供了一种限制输入值大小,并向用户显示错误提示的方法,确保圆圈不会超出屏幕范围。 对于Formidable Forms计算后圆圈大小不更新的问题,可以通过手动触发change事件或者直接在Formidable Forms的回调函数中更新圆圈的大小来解决。

以上就是在文本框内设置同心圆的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1579360.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 20:33:36
下一篇 2025年12月22日 20:33:46

相关推荐

  • Angular、Bootstrap、HTML 验证类统一化指南

    本文旨在解决 Angular 应用中,整合 Angular 内置验证、Bootstrap 样式以及 HTML 验证时,验证 CSS 类不统一的问题。通过自定义指令,将 Angular 的 .ng-valid 和 .ng-invalid 类转换为 Bootstrap 的 .is-valid 和 .is…

    2025年12月22日
    000
  • Angular、Bootstrap与HTML表单验证:统一验证样式指南

    本文旨在解决Angular、Bootstrap和HTML表单验证中CSS类名不统一的问题。通过自定义指令,将Angular的.ng-valid和.ng-invalid类转换为Bootstrap的.is-valid和.is-invalid类,从而简化代码并实现统一的验证样式,提升开发效率和用户体验。本…

    2025年12月22日
    000
  • Angular 表单验证与 Bootstrap 样式统一:最佳实践指南

    正如摘要所述,本文旨在解决 Angular 应用中表单验证样式不统一的问题,特别是当同时使用 Angular 内置验证器、CSS 伪类以及 Bootstrap 样式时。通过自定义指令,将 Angular 的 .ng-valid/.ng-invalid 状态与 Bootstrap 的 .is-vali…

    2025年12月22日
    000
  • 在文本框中设置同心圆

    本文旨在解决如何在网页文本框内创建和控制同心圆的问题。通过修改CSS样式,将圆圈定位在文本框内,并利用JavaScript动态调整圆圈大小。同时,提供限制用户输入值的示例,以及解决动态更新圆圈大小的问题,确保圆圈始终与输入值保持同步。 实现同心圆的基本结构 首先,我们需要一个容器(.circles)…

    2025年12月22日
    000
  • Angular 中统一验证 CSS 类的最佳实践

    本文旨在解决 Angular 项目中,内置验证器、Angular 验证器和 Bootstrap 样式验证类不统一的问题。通过自定义指令,将 Angular 的 valid 属性转换为 Bootstrap 的 .is-valid 和 .is-invalid 类,从而简化代码,实现验证样式的一致性,提升…

    2025年12月22日
    000
  • 使用 CSS 变量实现悬停时动态改变字体大小

    本文将详细介绍如何使用 CSS 变量在悬停状态下动态改变字体大小,并针对不同屏幕尺寸进行适配。核心思想是利用 CSS 变量存储字体大小,并在 :hover 伪类中通过 calc() 函数修改该变量的值,从而实现字体大小的动态变化。 利用 CSS 变量定义字体大小 首先,我们需要定义一个 CSS 变量…

    2025年12月22日
    000
  • Angular、Bootstrap与HTML表单验证:统一验证CSS类

    本文将探讨如何在Angular项目中,统一使用Bootstrap的验证样式,避免因Angular自带验证和Bootstrap验证使用不同的CSS类而导致的代码冗余。正如摘要所述,我们将创建一个自定义指令,将Angular的验证状态转换为Bootstrap的验证样式,从而简化开发流程。 自定义指令实现…

    2025年12月22日
    000
  • HTML代码调试:快速定位网页错误的实用工具推荐

    使用浏览器开发者工具可快速定位网页问题,通过检查元素、调试样式与脚本,结合W3C验证服务检测HTML合规性,并利用代码编辑器的实时预览功能提升修复效率。 如果您在开发或维护网页时遇到显示异常、功能失效或代码报错等问题,很可能是HTML结构或相关脚本存在错误。以下是几款实用的工具推荐,帮助您快速定位并…

    2025年12月22日
    000
  • HTML代码怎么链接外部样式_HTML代码链接CSS样式表的方法与最佳实践

    答案:通过在HTML的中使用链接外部CSS,实现结构与样式的分离,提升维护性、复用性和性能。 HTML代码链接外部CSS样式表,核心是通过在HTML文档的部分使用标签来实现。这是一种将结构(HTML)与样式(CSS)分离的有效方式,有助于提升代码的可维护性、复用性,并优化页面加载性能。 解决方案 要…

    2025年12月22日
    000
  • 解决 React 组件导入与渲染问题:以标题和页脚为例

    本文针对 React 应用中组件(如标题和页脚)无法正确显示的问题,深入分析了常见的导入语法错误。通过一个实际案例,详细阐述了如何在 App.js 文件中正确导入组件,并强调了严格遵循 JavaScript 模块导入规范的重要性,确保页面元素能够顺利渲染。 在 react 开发中,构建模块化组件是提…

    2025年12月22日
    000
  • 将jQuery导航栏交互迁移至React:状态管理、Refs与副作用的实践

    本文详细阐述了如何将传统的jQuery导航栏交互逻辑(如点击切换菜单、滚动时添加固定样式)优雅地迁移至React框架。通过深入探讨React的状态管理(useState)、DOM引用(useRef)以及副作用钩子(useEffect),教程将指导开发者如何用声明式的方式重构命令式代码,从而构建高性能…

    2025年12月22日
    000
  • 优化 ARIA 实时区域:避免屏幕阅读器重复播报动态内容

    本文深入探讨了在开发动态 Web 应用时,如何有效利用 ARIA 实时区域(如 role=”log”)来确保屏幕阅读器正确播报内容更新。核心问题在于,当开发者清空并重新填充实时区域的父元素时,屏幕阅读器会重复播报所有内容。解决方案是避免整体替换,而应采用增量更新的方式,仅追加…

    2025年12月22日
    000
  • HTMLCSSAnimation关键帧动画的格式语法和步骤

    关键帧动画通过@keyframes定义动画序列,结合animation属性应用到元素,实现复杂视觉效果。1. 使用@keyframes设定动画名称与时间节点(如0%、50%、100%),可替换为from/to;2. 在CSS中通过animation-name、duration、timing-func…

    2025年12月22日
    000
  • 构建交互式JavaScript数组导航器:实现前后元素访问

    本文将指导您如何使用JavaScript、HTML和CSS构建一个交互式数组导航器。通过“上一项”和“下一项”按钮,用户可以顺序或逆序地浏览数组中的元素。教程将详细介绍如何管理当前索引、处理按钮点击事件以及动态更新页面内容,实现数组元素的便捷切换展示。 在现代Web应用中,经常需要展示列表数据并提供…

    2025年12月22日
    000
  • 怎样在网页上优雅地展示代码块?PRE和CODE标签的组合拳。

    使用PRE和CODE标签组合可语义化地展示代码,PRE保留格式,CODE声明代码语义,嵌套使用并添加language-类名以支持语法高亮,通过CSS设置等宽字体、背景色、圆角、内边距及滚动,结合Prism.js等工具实现美观可读的代码展示。 在网页中展示代码,既要保证可读性,又要保持样式美观。使用 …

    2025年12月22日
    000
  • CSS布局深度解析:告别margin: auto的垂直居中误区与现代解决方案

    本文旨在澄清CSS中margin: auto属性在垂直居中方面的常见误区,并深入探讨如何利用Flexbox和CSS Grid这两种现代布局技术,实现元素在容器内精准的水平和垂直居中。通过详细的原理讲解和代码示例,帮助开发者掌握高效、灵活的居中策略,告别传统布局的困扰。 1. 引言:margin: a…

    2025年12月22日
    000
  • 如何使图片在 Bootstrap 模态框中占据 100% 的容器空间

    本文将介绍如何在 Bootstrap 模态框中使图片占据 100% 的容器空间,避免图片超出模态框范围或出现滚动条。通常,设置 max-height 可能会阻止图片缩小以适应容器。通过使用 height 属性结合 object-fit 属性,并配合 overflow: auto 实现滚动,可以有效地…

    2025年12月22日
    000
  • 消除Header与Navbar之间的空白:CSS样式调整指南

    本文旨在解决网页设计中常见的Header和Navbar之间出现空白的问题。通过分析CSS样式,我们将探讨如何通过调整margin、padding等属性,以及使用正确的HTML结构,来有效消除这些空白,实现页面元素的无缝衔接,提升用户体验。本文将提供详细的CSS代码示例,帮助你快速解决类似问题。 理解…

    2025年12月22日
    000
  • HTML注释能包含链接吗_注释中URL地址的处理方式

    HTML注释可包含URL,但仅作为源码中的纯文本,不影响渲染或SEO,常用于开发者内部参考,如链接设计稿、API文档等,但需注意信息泄露和维护成本风险。 HTML注释里当然可以包含URL地址,这在技术上是完全允许的。浏览器在解析页面时,会将注释块内的所有内容都当作纯文本来处理,不会尝试渲染它,更不会…

    2025年12月22日
    000
  • html实现时间动态显示 html当前时间获取教程

    首先通过JavaScript的Date对象获取当前时间,并格式化年月日时分秒,然后将格式化后的时间插入HTML的指定元素中,最后使用setInterval每秒调用一次更新函数,实现页面实时显示时钟效果。 如果您希望在网页上实时显示当前的时间,可以通过JavaScript结合HTML来动态获取并更新系…

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信