当前位置 : 主页 > 网络编程 > JavaScript >

解决Vue input输入框卡死的问题

来源:互联网 收集:自由互联 发布时间:2023-02-08
原因 我把 vuex 全局变量 $store.state.search.key 绑定到 v-model 上,然后在页面挂载时通过代码修改 $store.state.search.key 的值,最后在页面上输入任意值 input 框就卡住了 解决方法 1.input 标签增

原因

我把 vuex 全局变量 $store.state.search.key 绑定到 v-model 上,然后在页面挂载时通过代码修改 $store.state.search.key 的值,最后在页面上输入任意值 input 框就卡住了

解决方法

1.input 标签增加 @input 属性

<input v-model='$store.state.search.key' @input="forceUpdateInput">

2.methods 中增加对应方法

forceUpdateInput(){this.$forceUpdate();}

补充:下面看下Vue-element中el-input输入卡顿问题

最近使用Vue-element时,遇到了el-input输入卡顿问题,影响用户体验,如下

el-input是这样写的,没有加额外的事件

<el-input v-model="code" placeholder="code" type="textarea" :rows="1"/>

解决方法
使用.lazy修饰符
使用.lazy的修饰符可以取消v-model的双向绑定,避免输入改变增加队列造成卡顿

注意:el-input底层代码会将文本框用div包裹,

所以直接在el-input中使用.lazy修饰符是不成功的,测试了这种写法确实无效

//不成功的使用方法
<el-input v-model.lazy="code" placeholder="code"></el-input>
//成功的使用方法("el-textarea__inner"类可以让样式与框架一致)
<textarea class="el-textarea__inner" v-model.lazy="code" placeholder="code"></textarea>

 textarea class="el-textarea__inner"成功的替换了el-input,并且.lazy生效了,不卡顿了,nice

到此这篇关于Vue input输入框卡死的解决办法的文章就介绍到这了,更多相关Vue input输入框内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

上一篇:vue如何在style标签中使用变量(数据)详解
下一篇:没有了
网友评论