1

两个问题:

查看https://github.com/bwu-dart/bwu_datagrid/blob/master/example/src/composite_editor_item_details/app_element.dart#L120中突出显示的行

1)为什么行

var idx = e.validationResults.errors.length;

总是抛出错误?

异常:未捕获的错误:空对象没有 getter 'length'。

NoSuchMethodError: method not found: 'length'
Receiver: null
Arguments: []
Stack Trace:
#0      Object.noSuchMethod (dart:core-patch/object_patch.dart:45)
#1      validationErrorHandler (http://localhost:8080/epimss_design.html.12.dart:184:42)
#2      _RootZone.runUnaryGuarded (dart:async/zone.dart:1020)
#3      _BufferingStreamSubscription._sendData (dart:async/stream_impl.dart:341)
#4      _BufferingStreamSubscription._add (dart:async/stream_impl.dart:270)
#5      _SyncBroadcastStreamController._sendData (dart:async/broadcast_stream_controller.dart:346)
#6      _BroadcastStreamController.add (dart:async/broadcast_stream_controller.dart:237)
#7      EventBus.fire (package:bwu_datagrid/core/event_bus.dart:61:19)
#8      _commitCurrentEdit (package:bwu_datagrid/bwu_datagrid.dart:3626:25)
#9      EditorLock.commitCurrentEdit (package:bwu_datagrid/core/range.dart:235:82)
#10     BwuDatagrid._commitEditAndSetFocus (package:bwu_datagrid/bwu_datagrid.dart:3045:40)
#11     _handleKeyDown (package:bwu_datagrid/bwu_datagrid.dart:2632:39)

其他属性也会发生同样的事情,例如字段和列等。

2)如何测试validationResult是否返回true?错误处理程序似乎只在存在 ValidationError 时触发。

我的验证器如下所示

 import 'package:bwu_datagrid/datagrid/helpers.dart' show Column, GridOptions,
    MapDataItem, MapDataItemProvider;
  import 'package:bwu_datagrid/bwu_datagrid.dart' show BwuDatagrid;
  import 'package:bwu_datagrid/formatters/formatters.dart' show CheckmarkFormatter;
  import 'package:bwu_datagrid/editors/editors.dart' show CheckboxEditor, EditorArgs,
    IntegerEditor, TextEditor;
  import 'package:bwu_datagrid/core/core.dart' show AddNewRow, ActiveCellChanged,
    ItemBase, ValidationError;
  import 'package:bwu_datagrid/plugins/row_selection_model.dart' show RowSelectionModel;

  import 'package:epimss_podo/reg.dart' show Email, EMAIL_FORM_EVENT;
  import 'package:epimss_shared/shared.dart' show toggleCoreCollapse, onBwuCellChangeHandler;
  import 'package:epimss_shared/validators.dart' show BwuRequiredEmailValidator,
    BwuRequiredNounValidator;

自定义验证器:

const String REQUIRED_EMAIL_REGEX = r"\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\b";
const String REQUIRED_NOUN_REGEX = r"\b[a-z'-]{2,}\b";

final RegExp _requiredNounValidator = new RegExp( REQUIRED_NOUN_REGEX, caseSensitive: false );
bool isRequiredNounValid( String property ) =>
    _requiredNounValidator.hasMatch( property );

final RegExp _requiredEmailPropertyValidator = new RegExp( REQUIRED_EMAIL_REGEX, caseSensitive: false );
bool isRequiredEmailPropertyValid( String property ) => _requiredEmailPropertyValidator.hasMatch( property );


class BwuRequiredEmailValidator extends bwu.Validator {
  bwu.ValidationResult call( dynamic value ) {
    if ( isRequiredEmailPropertyValid( value ) ) {
      return new bwu.ValidationResult( true );
    } else {
      return new bwu.ValidationResult( false, 'Valid email address required.' );
    }
  }
}


class BwuRequiredNounValidator extends bwu.Validator {
  bwu.ValidationResult call( dynamic value ) {
    if ( isRequiredNounValid( value) ) {
      return new bwu.ValidationResult( true );
    } else {
      return new bwu.ValidationResult( false, 'Valid noun is required.' );
    }
  }
}

验证错误处理程序:

void validationErrorHandler( ValidationError e ) {
  //print ( e.validationResults.errors.length );
  print ( e.column.field );

  if ( e.validationResults.isValid )
    print( 'retVal is true' );
  else
    print( 'retVal is false' );

  errorMsg = e.validationResults.message;
  var editor = e.editor;
  print ( 'valResult valid |' + e.validationResults.isValid.toString() );

  var result = e.validationResults;

  if ( e.validationResults.isValid ) {
    errorMsg = 'EMAIL';
  } else {
    errorMsg = result.message;
  }

  print( editor.runtimeType ); // aslways print TextEditor

  if ( editor != null ) {
    //var colId = editor.column.id;
    if ( editor is TypeEditor ) {
      email.isTypeValid = true;
    }

    if ( editor is AddressEditor ) {
      email.isAddressValid = false;
    }

    //print( encode ( email ) );
  }
}
4

1 回答 1

0

您会收到异常,因为该字段e.validationResults.errors为空。
您无法访问 的length属性,null因此引发异常。
该字段errors为空,因为在此调用中

return new bwu.ValidationResult( false, 'Valid email address required.' );

您没有为可选errors参数传递值

class ValidationResult {
  bool isValid = false;
  String message;
  List<ValidationErrorSource> errors;

  ValidationResult(this.isValid, [this.message, this.errors]);
}

暗示:

据我所知,断点不适用于标签内的<script>代码(我在电子邮件中收到的示例代码中看到了这一点)。
因此,我建议将您的代码从email_form.html文件移动到email_form.dart文件。
然后您可以使用调试器并在运行时调查这些值,这也有助于了解其他人的代码实际在做什么。

在此处输入图像描述

从编辑器触发自定义事件

class AddressEditor extends bwu.TextEditor {

static const VALIDATION_SUCCEEDED = const EventType<ValidationError>(
      'custom-validation-succeeded');
  ...

@override
bwu.ValidationResult validate() {
  var result = super.validate();

  args.grid.eventBus.fire(AddressEditor.VALIDATION_SUCCEEDED, new ValidationError(this,
    editor: this,
    cellNode: args.grid.getActiveCellNode(),
    validationResults: result,
    cell: args.grid.getActiveCell(),
    column: column));
  return result;
}

// 您可以注册与验证错误事件相同的处理程序 grid.eventBus.onEvent(AddressEditor.VALIDATION_SUCCEEDED).listen(validationErrorHandler);

我没有尝试过这段代码,但它应该可以工作。

于 2014-09-06T10:29:14.363 回答