ie8文件上传onchange无效

本文讨论了在使用IE8浏览器时遇到的文件上传onchange事件无效的问题,详细介绍了问题产生的原因——file的click事件由按钮触发导致无效,并提供了通过使input标签完全覆盖a标签来解决该问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于ie8文件上传onchange事件无效

前几天,在修改一个关于文件上传bug时,发现谷歌,火狐都能顺利上传,唯独ie8无法上传。经过调试,原因是没有触发onchange事件,而主要的原因是,file的click事件是由它旁边的按钮通过dispatchEvent而触发,所以导致无效。解决方案:

    <a href="javascript:void(0)">上传</a>
    <input type="file" style="opacity:0;position:absolute;z-index:1000;left:0"/>

使上面的input完完全全覆盖a标签,即可完成解决问题。

出现 `onchange` 无效的情况可能有以下几种原因: 1. 检查 `onchange` 方法是否正确定义,以及是否正确命名。方法名应该以 `onchange_` 开头,其后跟着字段名称。例如,如果你想在 `product_id` 字段上定义 `onchange` 方法,那么方法名应该是 `onchange_product_id`。 2. 检查 `onchange` 方法是否正确绑定到相应的字段上。你应该在相应的字段中使用 `onchange` 属性来绑定定义好的 `onchange` 方法。例如,如果你想在 `product_id` 字段上定义 `onchange` 方法,那么应该在该字段的视图中添加 `onchange` 属性,如下所示: ``` <field name="product_id" on_change="onchange_product_id(product_id)"/> ``` 3. 检查 `onchange` 方法是否正确返回值。`onchange` 方法应该返回一个字典,其中包含要更新的字段和其对应的新值。例如,如果你想在 `product_name` 字段上更新新值,那么可以在 `onchange` 方法中添加以下代码: ``` @api.onchange('product_id') def onchange_product_id(self): if self.product_id: self.product_name = self.product_id.name else: self.product_name = False return {'value': {'product_name': self.product_name}} ``` 这个方法将在 `product_id` 字段值发生变化时被调用,并且将根据选择的产品更新 `product_name` 字段的值。 4. 最后,确保你的模型继承了正确的父类。如果你的模型继承了 `models.Model`,那么你需要添加 `@api.onchange` 装饰器来定义 `onchange` 方法。如果你的模型继承了 `osv.osv`,那么你需要添加 `def onchange_***()` 方法来定义 `onchange` 方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值