如何检查InputElement是否为Dart中的复选框

时间:2015-03-24 05:44:22

标签: html json dart dart-html

我在dart中将一些表单序列化为JSON:html

Map jsonifyForm(String formQuery){

  FormElement form = querySelector(formQuery);

  Map<String, String> data = {};

  List<InputElement> inputs = form.querySelectorAll("input.json");
  for (InputElement input in inputs) {

    if (input is CheckboxInputElement){
      print("checkbox: " + input.name + "|" + input.checked.toString());
      data.putIfAbsent(input.name, () => input.checked);
    } else {
      print("text: " + input.name + "|" + input.value);
      data.putIfAbsent(input.name, () => input.value);
    }
  }

  print(data);
  return data;
}

我在页面上有大约100个输入字段,后面只有一个复选框:

<label>First Name</label>
<input type="text" class="form-control tip json" placeholder="First Name" name="firstName" value="" data-toggle="tooltip" data-placement="top" title="First Name"/>


<label>Last Name</label>
<input type="text" class="form-control tip json" placeholder="Last Name" name="lastName" value="" data-toggle="tooltip" data-placement="top" title="Last Name"/>

...

<label class="form-control tip" data-placement="top" title="VAT On Goods" data-toggle="tooltip">
<input class="json" type="checkbox" name="vatOnGoods">
VAT on goods
</label>

当我调用jsonifyForm时,我发现所有输入都被视为复选框:

checkbox: firstName|false
checkbox: lastName|false
...
checkbox: vatOnGoods|false

{firstName: false, lastName: false, ..., vatOnGoods: false}

这是一个错误还是我在这里做错了什么?

1 个答案:

答案 0 :(得分:3)

班级CheckboxInputElement仅提供valuechecked属性。我仍然想知道为什么它说这些都是复选框。但您可以查看type属性:

if(input.type == 'checkbox')

检查复选框的类型。