css - 如何使用简单的 css、js 更改输入闪烁插入符样式

标签 css caret input-field

我想知道如何使用 css/javascript 来用 CSS 调整搜索框中闪烁的光标?

enter image description here

是否可以将默认的闪烁插入符号替换为水平闪烁图标

最佳答案

我觉得没那么难。我做了一个简单的例子,它适用于除 Safari 之外的大多数现代浏览器。 它将插入符号绘制在 Canvas 上,并将其设置为输入的背景,位置是根据浏览器插入符号位置计算的。

它检查浏览器是否支持 caret-color css 属性,如果不支持,则不会执行任何操作,因为系统插入符和我们的插入符都将在同时。从我测试的浏览器来看,只有Safari不支持。

$("input").on('change blur mouseup focus keydown keyup', function(evt) {
  var $el = $(evt.target);
  //check if the carret can be hidden
  //AFAIK from the modern mainstream browsers
  //only Safari doesn't support caret-color
  if (!$el.css("caret-color")) return;
  var caretIndex = $el[0].selectionStart;
  var textBeforeCarret = $el.val().substring(0, caretIndex);

  var bgr = getBackgroundStyle($el, textBeforeCarret);
  $el.css("background", bgr);
  clearInterval(window.blinkInterval);
  //just an examplethis should be in a module scope, not on window level
  window.blinkInterval = setInterval(blink, 600);
})

function blink() {
 
  $("input").each((index, el) => {
    var $el = $(el);
    if ($el.css("background-blend-mode") != "normal") {
      $el.css("background-blend-mode", "normal");
    } else {
      $el.css("background-blend-mode", "color-burn");
    }
  });
}


function getBackgroundStyle($el, text) {
  var fontSize = $el.css("font-size");
  var fontFamily = $el.css("font-family");

  var font = fontSize + " " + fontFamily;
  var canvas = $el.data("carretCanvas");
  //cache the canvas for performance reasons
  //it is a good idea to invalidate if the input size changes because of the browser text resize/zoom)
  if (canvas == null) {
    canvas = document.createElement("canvas");
    $el.data("carretCanvas", canvas);
    var ctx = canvas.getContext("2d");
    ctx.font = font;
    ctx.strokeStyle = $el.css("color");
    ctx.lineWidth = Math.ceil(parseInt(fontSize) / 5);
    ctx.beginPath();
    ctx.moveTo(0, 0);
    //aproximate width of the caret
    ctx.lineTo(parseInt(fontSize) / 2, 0);
    ctx.stroke();
  }
  var offsetLeft = canvas.getContext("2d").measureText(text).width + parseInt($el.css("padding-left"));
  return "#fff url(" + canvas.toDataURL() + ") no-repeat " +
    (offsetLeft - $el.scrollLeft()) + "px " +
    ($el.height() + parseInt($el.css("padding-top"))) + "px";
}
input {
  caret-color: transparent;
  padding: 3px;
  font-size: 15px;
  color: #2795EE;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text" />

如果有兴趣,我可以稍微清理一下并将其包装在 jQuery 插件中。

编辑:忘记了闪烁,所以我添加了它。更好的方法是将其添加为 css 动画,在这种情况下,插入符应该位于位于输入上方的单独 html 元素中。

关于css - 如何使用简单的 css、js 更改输入闪烁插入符样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45184355/

相关文章:

java - 在 JScrollPane 上设置插入符位置

salesforce - 带有自定义错误消息的输入字段必填标记

html css - li 的文本对齐方式

html - 悬停时更改列表项元素符号/数字颜色

c# - 插入符未显示在文本框中

c# - 如何在unity3d中隐藏InputField附加输入框

typescript - 如何使用 Angular 2+ 禁用键盘按键。但是,键应该在 HTML 输入字段上工作

html - 如何提供独立于文件类型的缩略图形式的文档预览

jquery - 如何将网站缩小25%

html - Bootstrap 护理人员 : Making sub carets and float them to the right?