解决js获取innerHTML无法获取value的问题

<form id="f1">
<input type="text"><input type="text"><input type="text">
<textarea></textarea>
<select></select>
</form>
<button οnclick="alert(getHtml(true,'f1'))">获取表单innerHTML</button>
<button οnclick="setHTML(false,"f1")">设置div的innerHTML,不做处理</button>
<button οnclick="setHTML(true,"f1")">设置div的innerHTML,处理数据并且设置状态</button>
<div id="dv"></div>
<script>
    function setHTML(process,formID) {
        $('#dv').html(getHtml(process, formID));
        if (!window.ActiveXObject && process) { //处理标准浏览器下select对象的option选择问题
            var arr, selector = '', i;
            $('#dv option[selectedx]').each(function () {    $(this).attr('selected', true).removeAttr('selectedx');  });
            //textarea有value属性没用,不会显示在输入框内,需要用js设置过value属性一次
            $('#dv textarea').each(function () { $(this).val(this.getAttribute('value')); });
        }
    }
    function getHtml(process,formID) {
        if (window.ActiveXObject || !process) { return $("#" + formID).html(); }
        else
        {//标准浏览器,需要重新控件的value属性,要不返回容器的innerHTML输入的内容或者选择状态并不会通过innerHTML属性获取到
            $($("#" + formID)[0].elements).each(function () {
                switch (this.tagName) {
                    case 'INPUT':
                    case 'TEXTAREA':
                        switch (this.type)
                        {
                            case 'radio':
                            case 'checkbox':
                                if (this.checked) this.setAttribute('checked', true);
                                else this.removeAttribute('checked'); //要记得删除,要不默认的选择会随innerHTML一起返回
                                break;
                            default:
                                this.setAttribute('value', this.value);
                        }
                        break;
                    case 'SELECT':
                        $('option', this).removeAttr('selectedx').not(':selected').removeAttr('selected').end().filter(':selected').attr('selectedx', 'selected');
                        break;
                }
            });
            return $("#" + formID).html();
        }
    }
</script>

转载于:https://my.oschina.net/lichaoqiang/blog/192588

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值