抹茶芋泥 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 基带到底是什么?为什么手机厂和厂外完全两个概念
    • ¥15 怎么下载MySQL,怎么卸干净原来的MySQL
    • ¥15 网络打印机Ip地址自动获取出现问题
    • ¥15 求局部放电案例库,用于预测局部放电类型
    • ¥100 QT Open62541
    • ¥15 stata合并季度数据和日度数据
    • ¥15 谁能提供rabbitmq,erlang,socat压缩包,记住版本要对应
    • ¥15 Vue3 中使用 `vue-router` 只能跳转到主页面?
    • ¥15 用QT,进行QGIS二次开发,如何在添加栅格图层时,将黑白的矢量图渲染成彩色
    • ¥50 监控摄像头 乐橙和家亲版 保存sd卡的文件怎么打开?视频怎么播放?