Vue实现input宽度随文字长度自适应操作


Posted in Javascript onJuly 29, 2020

Vue实现input宽度随文字长度自适应操作

业务需求,输入文字,后面的元要紧随其后,奈何input默认是有宽度,我想要达到,输入文字,动态改变input的宽度,试了很多方法,目前自己琢磨一种,有遇到问题的可以参考一下,

直接贴代码

<div class="textcontain">
     <input
      type="text"
      v-model.number="item.cardComboMoney"
      maxlength="5"
      placeholder="设定数值"
      oninput="value=value.replace(/^(0+)|[^\d]+/g,'')"
      :disabled='disabled'
      :style="{width:text(item.cardComboMoney)}"
     >
     <span
      class="textshow"
      v-if="item.cardComboMoney!=0&&item.cardComboMoney!=''"
     >元</span>
    </div>
computed: {
  text () {
   return function (value) {
    if (value == '' || value == 0) {
     return '100%'
    } else {
     return String(value).length * 0.32 + 'rem'
    }
   }
  }
 },

利用计算属性,计算当前字体的长度,我这里最多允许输入5个字符的长度,所以这样计算影响不大

补充知识:input宽度自适应(解决文字占位宽度不同所引起的问题)

问题描述:

input在输入的时候,要能让input的宽度随着输入的文字自动增宽。

思路1:获取文字的内容,然后通过文字.length * font-size计算文字的宽度,但是由于文字“i”与“中”显然占位宽度不同而引起宽度差

思路:

设置一个隐藏的span,使其font属性与input统一,然后获取span的宽度,赋值给input

<!DOCTYPE html>
<html lang="en">
 
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.js"></script>
 <title>input宽度自适应</title>
 <style>
  body {
   font-size: 16px;
   font-family: Arial, Helvetica, sans-serif;
  }
 
  #my-input {
   width: 20px;
   padding: 0;
   font-size: 16px;
   font-family: Arial, Helvetica, sans-serif;
  }
 
  #my-span {
   position: absolute;
   left: 0;
   visibility: hidden;
  }
 </style>
</head>
 
<body>
 <!-- 思路:将文字内容赋值给隐藏的span,然后将input的宽度设置为span的宽度 -->
 <span id="my-span"></span>
 <input type="text" id="my-input" oninput="changeWidth()">
 
 <script>
  function changeWidth() {
   var mySpan = $("#my-span");
   var myInput = $("#my-input");
   mySpan.html(myInput.val()); //给span赋值
   if (mySpan.width() > 20) {
    myInput.css('width', mySpan.width());
   }
  }
 </script>
</body>
 
</html>

以上这篇Vue实现input宽度随文字长度自适应操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
身份证号码前六位所代表的省,市,区, 以及地区编码下载
Apr 12 Javascript
jquery实现简单的无缝滚动
Apr 15 Javascript
js实现表单Radio切换效果的方法
Aug 17 Javascript
jqGrid 学习笔记整理——进阶篇(一 )
Apr 17 Javascript
Jquery遍历select option和添加移除option的实现方法
Aug 26 Javascript
js实现百度搜索提示框
Feb 05 Javascript
Vue+axios 实现http拦截及路由拦截实例
Apr 25 Javascript
jquery replace方法去空格
May 08 jQuery
AngularJS中下拉框的基本用法示例
Oct 11 Javascript
SVG实现时钟效果
Jul 17 Javascript
element-ui如何防止重复提交的方法步骤
Dec 09 Javascript
编写一个javascript元循环求值器的方法
Apr 14 Javascript
vue 判断元素内容是否超过宽度的方式
Jul 29 #Javascript
在vue中实现给每个页面顶部设置title
Jul 29 #Javascript
vue实现移动端项目多行文本溢出省略
Jul 29 #Javascript
ElementUI 修改默认样式的几种办法(小结)
Jul 29 #Javascript
Element中Slider滑块的具体使用
Jul 29 #Javascript
vue 实现超长文本截取,悬浮框提示
Jul 29 #Javascript
javascript实现移动端触屏拖拽功能
Jul 29 #Javascript
You might like
也谈截取首页新闻 - 范例
2006/10/09 PHP
php HTML无刷新提交表单
2016/04/05 PHP
搜索附近的人PHP实现代码
2018/02/11 PHP
fromCharCode和charCodeAt 方法
2006/12/27 Javascript
javascript 模式设计之工厂模式学习心得
2010/04/27 Javascript
遍历DOM对象内的元素属性示例代码
2014/02/08 Javascript
jQuery中delegate()方法用法实例
2015/01/19 Javascript
JavaScript整除运算函数ceil和floor的区别分析
2015/04/14 Javascript
DOM 高级编程
2015/05/06 Javascript
JavaScript设置表单上传时文件个数的方法
2015/08/11 Javascript
基于jQuery实现美观且实用的倒计时实例代码
2015/12/30 Javascript
实例详解AngularJS实现无限级联动菜单
2016/01/15 Javascript
jquery获取复选框的值的简单实例
2016/05/26 Javascript
深入理解js数组的sort排序
2016/05/28 Javascript
再谈Javascript中的基本类型和引用类型(推荐)
2016/07/01 Javascript
Web安全测试之XSS实例讲解
2016/08/15 Javascript
js与jquery分别实现tab标签页功能的方法
2016/11/18 Javascript
JS实现JSON.stringify的实例代码讲解
2017/02/07 Javascript
yarn的使用与升级Node.js的方法详解
2017/06/04 Javascript
浅谈node中的exports与module.exports的关系
2017/08/01 Javascript
浅谈js中的this问题
2017/08/31 Javascript
完美解决手机浏览器顶部下拉出现网页源或刷新的问题
2017/11/30 Javascript
小程序实现带年月选取效果的日历
2018/06/27 Javascript
js微信分享接口调用详解
2019/07/23 Javascript
从零撸一个pc端vue的ui组件库( 计数器组件 )
2019/08/08 Javascript
在Vue里如何把网页的数据导出到Excel的方法
2020/09/30 Javascript
如何在现代JavaScript中编写异步任务
2021/01/31 Javascript
python装饰器decorator介绍
2014/11/21 Python
python二维列表一维列表的互相转换实例
2018/07/02 Python
4行Python代码生成图像验证码(2种)
2020/04/07 Python
计算机维护专业推荐信
2014/02/27 职场文书
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
《孔繁森》教学反思
2014/04/17 职场文书
可可西里观后感
2015/06/08 职场文书
疑《守望先锋2》A测截图泄露 或将推出新模式、新界面
2022/04/03 其他游戏
关于的python五子棋的算法
2022/05/02 Python