为什么我的代码只在一台电脑上取值失败?
为什么取值失败,偏偏只在某一台电脑上出现
在 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 等框架,这有助于理解底层原理和提高兼容性处理能力。
以上就是为什么我的代码只在一台电脑上取值失败?的详细内容,更多请关注www.sxiaw.com其它相关文章!