JavaScript input输入数值(value)无效的原因和解决办法

    会碰到这个问题一般是想×别人的网页导致的,一般来说想控制别人写的网页(或者维护一份别人的网页代码)碰到需要用JS给input或者select之类的组件赋值的时候一般会直接这样写:

  let casess=document.getElementsByClassName('xxxxx')[0];

  casess.value='50';

    赋值后点击有时候会报错有时候不会,一般报错的情况基本上属于这份代码用了某些前端框架,例如Vue之类的,Vue的input弄个双向绑定啥的,此时我们用原生的JS企图去控制输入框的值就会出现无效的情况(明明input上有数字或者字符但是点击按钮就是说你没填内容)。因为此时只是修改了value属性,没有触发input或change事件,导致输入没有最终确定。input和change事件默认情况下(作者设计的时候),只有当接收到键盘的按键(随便哪个键盘的按键消息),就会触发input和change事件,进而把输入框中的value赋值给预设的相关变量,到这一步才算走完整个设置value的过程。所以如果想给这类加料的输入框或者选择框用原生JS赋值,设置vlaue属性过后就必须手动触发一下input或change事件。下面是例子:

    input的例子:

  let casess=document.getElementsByClassName('input_amo')[0];
    //input_amo -- 是input的类

  casess.value='50';

    var event = document.createEvent('HTMLEvents');
    event.initEvent("input", true, true);
    event.eventType = 'message';
    casess.dispatchEvent(event);

    如果是select选择框把"input"改成"change"即可,更多信息请看参考资料。

参考资料:https://blog.csdn.net/russle/article/details/67637500

————————————————————————

2023.11.2 更新

上面那个方法有的网页会失效,可能VUE啥的框架又改了什么地方,下面是测试后可用的新方法:

var hulfen = document.getElementsByClassName("Ikun")[0];

var ount =hulfen.children[1];

changeReactInputValue(ount,"5");

//调用下面这个函数可以给框架包装过的input框赋值
function changeReactInputValue(inputDom,newText){
    let lastValue = inputDom.value;
    inputDom.value = newText;
    let event = new Event('input', { bubbles: true });
    event.simulated = true;
    let tracker = inputDom._valueTracker;
    if (tracker) {
      tracker.setValue(lastValue);
    }
    inputDom.dispatchEvent(event);
}
 

至于原理是啥就整不明白了,如果有知道的道友欢迎留言说说。

当你在Vue3项目中使用Swiper v7.2.0组件,并尝试通过`mySwiper.value.swiper.slidePrev()`这样的语法控制滑动,发现它不生效的话,可能是由于以下几个原因: 1. **数据绑定**:确保你在组件模板上正确地绑定了Swiper实例。例如,使用`ref`或`:ref`属性,然后在methods中通过`this.$refs.mySwiper.swiper.slidePrev()`访问。 ```html <template> <div ref="mySwiper" :swiper="swiperOptions"> <!-- ... --> </div> </template> <script setup> import { ref } from 'vue'; import Swiper from 'swiper'; const swiperOptions = { // ... }; const mySwiperRef = ref(); const swiper = new Swiper(mySwiperRef.value, swiperOptions); onMounted(() => { // 初始化Swiper并挂载到DOM元素上 mySwiperRef.value.$el.swiper = swiper; }); </script> ``` 2. **生命周期钩子**:初始化Swiper应该在`mounted`钩子函数中完成,而不是直接在JavaScript代码中。确保已经完成了初始化过程。 3. **事件监听**:如果需要在特定事件触发后调用slidePrev,确保你已正确设置事件处理器。如`onSlideChangeStart`、`onSlideChanged`等。 4. **异步问题**:有时候可能会遇到数据加载延迟导致的初始状态错误,检查是否需要添加一个等待条件,直到数据准备就绪再操作Swiper。 5. **版本兼容性**:确认ViteVue3是否都与Swiper库完全兼容。如有必要,可以尝试降级或升级Swiper版本看是否能解决问题。 如果以上都没有解决,试着查看浏览器开发者工具中的错误信息,以便找到问题的具体所在。
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值