
为什么取值失败,偏偏只在某一台电脑上出现
在 html 文档中,获取元素时遇到了这样一个问题:
var radios = document.getelementsbyname("index");for (var i = 0; i < radios.length; i++) { var radioi = radios[i]; if (radioi.checked == true) { var flwcode = radioi.flwcode; // 取值失败 var taskid = radioi.taskid; // 取值失败 }}
在所有电脑上都正常执行,唯独一台电脑会取值失败。
问题解答
出现这个问题的原因在于,flwcode 和 taskid 是非标准属性。在大多数浏览器中,可以使用点语法直接获取这些属性的值,但某些浏览器并不兼容。
想要解决这个问题,可以采用以下方法:
使用 getattribute 方法
getattribute 方法可以获取元素的任何属性,包括非标准属性。示例代码:
var flwcode = radioi.getattribute("flwcode");var taskid = radioi.getattribute("taskid");
使用 data-* 属性
data-* 属性是 html5 中新增的,专门用来存储非标准数据。示例代码:
var flwCode = radioI.getAttribute("data-flw-code");var taskId = radioI.getAttribute("data-task-id");
需要注意的是,getattribute 方法虽然兼容性较好,但并非所有的属性都能获取。而 data-* 属性的兼容性较差,建议在必要时使用。
至于学习方法,建议先掌握原生 javascript 的基础知识,然后再学习 jquery 等框架,这有助于理解底层原理和提高兼容性处理能力。
以上就是为什么我的代码只在一台电脑上取值失败?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1495632.html
微信扫一扫
支付宝扫一扫