- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
所以我遇到了一些问题。
我一直在努力寻找一种方法来使 input
元素的宽度适合内容。我一直在取得进步,但无论出于何种原因,该方法都不起作用。所以现在我在这里寻求帮助。我将分享我尝试过但最终对我不起作用的方法。
注意:对于所有这些尝试,我都使用 ctx.measureText(text)
来帮助获取文本的宽度
另一个注意事项:可能无法修复,如果不能修复也没关系,但是对于所有这些方法,如果您按住某个键,宽度直到最后才会更新并重复
方法一:按键事件
var ctx = document.querySelector('canvas').getContext('2d');
var input = document.querySelector('input');
ctx.font = window.getComputedStyle(input).getPropertyValue('font-size')+' '+window.getComputedStyle(input).getPropertyValue('font-family');
input.addEventListener('keyup', () => {
input.style.width = `${ctx.measureText(input.value).width+3}px`;
});
<input placeholder="Placeholder"></input>
<canvas style="display: none;"></canvas>
到目前为止,这是我认为最好的方法。然而,它工作得很好,因为它在 keyup 事件上触发,直到字符被键入后它才改变宽度,这会产生抖动效果。
方法二:keyup事件加padding
var ctx = document.querySelector('canvas').getContext('2d');
var input = document.querySelector('input');
ctx.font = window.getComputedStyle(input).getPropertyValue('font-size')+' '+window.getComputedStyle(input).getPropertyValue('font-family');
input.addEventListener('keyup', () => {
input.style.width = `${ctx.measureText(input.value+'W').width+3}px`;
});
<input placeholder="Placeholder"></input>
<canvas style="display: none;"></canvas>
此方法与上一个方法相同,但我添加了字符“W”宽度的填充(因为它是几乎所有字体中最宽的字母)。这消除了抖动效果,但完成后会留下不必要的空间量。
除了在模糊事件中将其更改为适当的宽度外,我还尝试这样做,但这在我的程序中导致了一个主要的(不相关的)错误。
你也可以使用 change 事件,但是如果有人按下了一个没有输入字符的键,比如 Alt,它会添加填充,然后由于没有变化,填充保持不变(你可以禁用元素聚焦时的事件监听器,但这非常低效且令人讨厌)。
您也可以仅在添加字符后才添加填充,但我能想到的仅有两种方法同样非常低效且令人讨厌。 (要么为输入的最后一个长度保留一个变量并查看它是否改变,要么使用 String.fromCharCode(event.keyCode)
大于 0)
方法 3: keydown with padding
var ctx = document.querySelector('canvas').getContext('2d');
var input = document.querySelector('input');
ctx.font = window.getComputedStyle(input).getPropertyValue('font-size')+' '+window.getComputedStyle(input).getPropertyValue('font-family');
input.addEventListener('keydown', () => {
input.style.width = `${ctx.measureText(input.value+'W').width+3}px`;
});
<input placeholder="Placeholder"></input>
<canvas style="display: none;"></canvas>
这比之前的方法稍微好一点,但同样存在问题。
此外,使用 keypress 与 keydown 的结果相同。我可以提供我尝试过的每个示例,但它们大多是上述所有内容的稍微不同的变体,所以我会让你们发挥创造力并尝试想出一个解决方案。
如果这是唯一的方式,我愿意使用 jQuery,但我更喜欢其他方式。
谢谢!
最佳答案
我会考虑另一个技巧。您可以在应用某些属性的位置使用可编辑的 div 以使其适合其内容(基本上使其成为内联元素),然后使用 JS 获取文本并将其放在输入中。
这是一个简单的例子。您只需要处理初始宽度并根据需要进行设置。您还可以使用 JS 轻松添加和删除占位符。
document.querySelector(".input").addEventListener("input", function(e) {
document.querySelector("input").value=e.target.innerHTML;
}, false);
.input {
border:1px solid #000;
display:inline-flex;
min-width:20px;
}
<div class="input" contenteditable="true">
</div>
<input type="hidden">
关于javascript - 输入宽度适合内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51127429/
我正在制作一个简单的程序来更改我的计算机背景。我在网上发现了一个stackoverflow问题,或多或少涵盖了我想做的事情。我现在可以成功地将我的墙纸更改为平铺、居中和从在线图像 URL 拉伸(str
是的,这是另一个每组最大的问题之一!我已经尝试了几天,试图解决这个问题,但无济于事。我也一直在寻找,但我什至不知道我是否在正确的地方寻找。问题的最简化版本如下。 我有 2 个表,一个是多对多表,另一个
我想解析一些数据,我有一个 BNF 语法来解析它。谁能推荐任何能够生成可在移动设备上使用的代码的语法编译器? 由于这是针对 JavaME 的,因此生成的代码必须是: 希望很小 对外来 Java 库的依
我有一个动物园时间序列对象,vels : 2011-05-01 00:00:00 7.52 2011-05-01 00:10:00 7.69 2011-05-01 00:20:00 7.67 2011
我想创建一个供小型制造公司使用的生产管理系统。该系统将允许记录设备制造的不同阶段。要求如下: 1.非基于浏览器的界面。需要基于 Swing 或 AWT 的东西。虽然我了解实现基于浏览器的解决方案的便利
是否有任何 java 或 clojure 邮件库可以实现 lamson 的功能?特别是lamson的邮件路由功能非常酷http://verpa.wordpress.com/2010/11/13/mak
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我正在致力于缩小和丑化我的 javascript 文件。我想知道合适的尺寸是多大。如果我将所有js文件合并成一个文件(经过缩小和丑化),它会大于1mb。我想,最好将它们分成 2-3 个文件(每个文件
我是 Java 新手。 我想在 GridPane 中放置一个 TextArea。我在过去几个小时内尝试了此操作,结果如下: 如您所见,TextArea 比我的 Gridpane 大得多。这是我的代码:
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我认为这是一个基本问题,但也许我混淆了这些概念。 假设我使用 R forecast 包中的函数 auto.arima() 将 ARIMA 模型拟合到时间序列。该模型假设方差不变。我如何获得该方差?是残
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我有一个很长的标签,这是我的第一个标签,我想把它放在我的单元格中。这就是我所拥有的,但它不起作用。 我有一个自定义的 UITabelviewCell ,里面有几个标签。 -(CGFloat)table
假设我有一个包含 WCS header 的 FITS 文件,这样我就可以执行以下操作: #import healpy as hp #import astropy.io.fits as pyfits #
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭10 年前。 Improve
我们正在构建一个与其他系统有多个集成接触点的应用程序。我们有效地使用 Unity 来满足我们所有的依赖注入(inject)需求。整个业务层是用接口(interface)驱动的方法构建的,实际实现在应用
我得到了 MKMapView 和一些注释。我使用下一个代码来显示所有注释: NSArray *coordinates = [self.mapView valueForKeyPath:@"annotat
我在一家托管公司工作,我们经常收到安装、新域、滞后修复等方面的请求。为了大致了解仍然开放的内容,我决定制作一个非常简单的票务系统。我有一点 php 知识和一点 MySQL 知识。目前,我们将根据客户的
我想向我的 UITableView 添加背景图像,它适合 UI,还具有导航 Controller 和工具栏。在那种情况下,我没有找到适合 iPhone 和 iPad 不同屏幕的 tableview 的
我是一名优秀的程序员,十分优秀!