满口金牙 2022-11-11 23:43 采纳率: 91.5%
浏览 34
已结题

vue input 自适宽度请教

vue input 根据内容自适宽度请教
用可编辑 div代替input不行, div 中不能用 v-model
根据input.value 的内容来确定宽度好象也不好用
请教 正确的方法

  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2022-11-12 12:15
    关注

    用一个absolute,top设置为负值定位到可视区域外的层来动态计算内容宽度在动态设置input的宽度,示例大概如下

    <style>
        .format{font-size:13px;font-family:'Microsoft YaHei';white-space:nowrap;}
    </style>
    <div id="app">
        <div ref="dv" class="format" style="position:absolute;left:0;top:-1000px">{{msg}}</div>
        <input type="text" v-model="msg" @input="setWidth" class="format" :style="`width:${width}px;min-width:100px`" />
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
    <script>
        var vue = new Vue({
            el: '#app',
            data: {
                msg: '',
                width: 100
            },
            methods: {
                setWidth() {
                    this.$nextTick(() => { this.width = this.$refs.dv.offsetWidth + 10;/*加上输入框的padding及border,如果有*/ });
                }
            }
        })
    </script>
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 11月21日
  • 已采纳回答 11月13日
  • 创建了问题 11月11日

悬赏问题

  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
  • ¥100 连续两帧图像高速减法