抹茶芋泥 2022-12-16 16:21 采纳率: 60%
浏览 17
已结题

获取table内的checkbox的同一行属性值无法获取到input框里的值

获取table内的checkbox的同一行属性值无法获取到input框里的值

想要获取页面展示的数据并存为一个List集合,但无法获取到input属性中的值

前端html里面的代码(grade为一个input框,输入后才有数据)

let list = json.data
   for (let i = 0;i < list.length;i++){
    let tr = '<span class="hljs-tag"><<span class="hljs-name">tr</span>></span>\n' +
        '<td><input name="snos" value="#{sno}" type="checkbox" onclick="showCol()" class="ckitem" /></td>\n' +
        '<td>#{sno}</td>\n' +
        '<td>#{sname}</td>\n' +
        '<td><input id="grade" name="grade" type="text" placeholder="成绩:"></td>\n' +
        '</tr>';
}

前端js代码

function showCol(){
            var checked = $("input[name='snos']:checked");//选中的复选框
            //循环被选中复选框的长度
            for (i = 0; i < checked.length; i++) {
                //创建一个对象
                var obj = {};
                //获取复选框选中的总行数里的i行
                var row = $("input[name=snos]:checked").parent("td").parent("tr")[i];
                //children获取的是子元素  []指要获取的第几个子元素  innerHTML取其html文本
                obj["sno"] = row.children[1].innerHTML;
                obj["sname"] = row.children[2].innerHTML;
                //请问怎么获取grade的值?是一个input框,row.getAttribute()方法获取不了

                console.log(row.children[1].innerHTML, row.children[2].innerHTML, row.getAttribute("grade"))
                //将对象存进数组
                array.push(obj);
            }
        }
  • 写回答

1条回答 默认 最新

  • 诗人远行 2022-12-16 16:27
    关注

    row.children[3].children[0].value

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月24日
  • 已采纳回答 12月16日
  • 创建了问题 12月16日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵