JavaScript Chrome vs IE

JavaScript Chrome vs IE

本文关键字:IE vs Chrome JavaScript      更新时间:2023-09-26

我有非常简单的JavaScript代码,可以将值从一个表单复制到另一个表单中。它在Chrome中运行良好,但在IE中并非所有内容都被复制。"状态字段"不会复制。状态字段实际上是"选择"字段。这是函数:

function FillMemberInfo(f){
      if(f.chkMemberInfo.checked == true) {
        f.member_firstname1.value = f.client_first_name.value;
        f.member_lastname1.value = f.client_last_name.value;
        f.member_address1.value = f.client_address.value;
        f.member_city1.value = f.client_city.value;
        f.member_state1.value = f.client_state.value;
        f.member_zip1.value = f.client_zip.value;
      } else {
        f.member_firstname1.value = "";
        f.member_lastname1.value = "";
        f.member_address1.value = "";
        f.member_city1.value = "";
        f.member_state1.value = "";
        f.member_zip1.value = "";
      }
    }
你不能

直接在<select>上设置.value,除非浏览器足够聪明。

尝试这样的事情:

function setSelectValue(sel,val) {
    var opts = sel.options, l = opts.length, i;
    for( i=0; i<l; i++) {
        if( opts[i].value == val) {
            sel.selectedIndex = i;
            return;
        }
    }
}

然后你可以做:

setSelectValue(f.member_state1, f.client_state.value);

应该注意的是,仍然较旧的浏览器不支持从<select>读取.value,理想情况下您应该这样做:

f.client_state.options[f.client_state.selectedIndex].value;