如何将后台的值显示到html对应的radio选项上?

<form method="post">
    roomName : <input type="text" name="roomName" value="<%=room.roomName%>"/><br/>
    roomContent:<textarea name="roomContent"><%=room.roomContent%></textarea><br/>
    roomCreateUser:<input type="text" value="<%=room.roomCreateUser%>" name="roomCreateUser"/><br/>
    roomChat:<input type="radio" name="roomChat" value="public" checked>公聊<input type="radio" name="roomChat" value="secret" >私聊<br/>
    <input type="hidden" name="id" value="<%=room._id%>"/>

    <input type="submit" value="submit"/>
    <input type="reset" value="reset"/>
</form>
<script>
    function chatradio(cName,cValue){
        var cObj = document.getElementsByName(cName);

        for(var i = 0;i < cObj.length;i++){
            if(cObj[i].value == cValue){
                cObj[i].checked =  'checked';
            }
        }
    };
    chatradio('roomchat','<%=room.roomChat%>');
</script>

我想将后台已经有的roomChat值给html页面上对应的值checked一下,再显示到html页面的对应选项上,在网上找到了上述的方法自己改了一下变成了上面的代码,但是哪里还出了问题,导致仍然不能正确checked后台的值?

阅读 4.2k
2 个回答

cObj没获取到值

每一组radio肯定在一个容器中,你可以给每一个容器定义一个id,比如说,每一组容器都放在一个div中,可以给第一个容器定义id为id1

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题