0

JS API 3.5 を使用しています。

Web アプリにエディター ウィジェットがあります。ウィジェットで [New Selection] をクリックすると、「Uncaught TypeError: Cannot read property 'preventDefault' of undefined」というエラーがスローされます

Chrome と Firefox では、コンソール ログにこのエラーがあっても描画して続行できますが、IE 11 はこの例外で中断します。

正確なエラー メッセージは、 http: //serverapi.arcgisonline.com/jsapi/arcgis/3.5/ の 34 行目、471861 列目の Unhandled exception です。

0x800a138f - JavaScript ランタイム エラー: 未定義または null 参照のプロパティ 'preventDefault' を取得できません

IE デバッグ ファイルでは、e の値が定義されていないコードのようになります。

_onClick:function(e){
        var ok=this.inherited(arguments);
        if(ok)
        {
           if(this.valueNode)           
        {           
          this.valueNode.click();
          e.preventDefault(); //e is undefined
          e.stopPropagation();}
        }
           return ok;
        }

ソースコードで見つけることができないため、この例外を処理する方法についての手がかりがありません。

以下に、エディター ウィジェットが作成されるコードを示します。

          require(["esri/dijit/editing/Editor",
                "esri/dijit/editing/TemplatePicker",
                 "dojo/domReady!"], lang.hitch(this, function (Editor, TemplatePicker) {

          console.log("click on new Editor => " + ops);
          this.editor = new Editor({
            'settings': ops
          }, editorContainer);
          this.editor.startup();
        }));

私は次のことを試みましたが、うまくいきませんでした: エディター ウィジェットが呼び出される前 - 変更

助けてください!

エディター ウィジェット onClick が呼び出されるコードは次のとおりです。

   define([
     'dojo/_base/declare',
     'dijit/_WidgetBase',
     'dijit/_TemplatedMixin',
     'dijit/_WidgetsInTemplateMixin',
      'dojo/_base/lang',
      'dojo/dom-construct',
         'dojo/domReady!'], function (declare, _WidgetBase, _TemplatedMixin, _WidgetsInTemplateMixin, lang, domConstruct) {

  return declare([_WidgetBase, _TemplatedMixin, _WidgetsInTemplateMixin], {
      templateString: '<div class="gis_GeoLocation_Dijit"><div style="text-align:center;"><button data-dojo-type="dijit/form/Button" data-dojo-attach-event="onClick:toggleEditing" data-dojo-props="label:\'Start Editing\',baseClass:\'geoLocationButton\'" style="background-color:#ECECEC;" data-dojo-attach-point="toggleBTN"></button></div><div style="margin-top:5px;" data-dojo-attach-point="containerNode"></div></div>',
    widgetsInTemplate: true,
    editor: null,
    isEdit: false,
    templatePicker: null,

    toggleEditing: function () {
      if (!this.isEdit) {
        var ops = lang.clone(this.settings);
        ops.map = this.map;
        ops.layerInfos = this.layerInfos;

        var templatePickerOptions = this.templatePickerOptions;
        templatePickerOptions.featureLayers = this.templatePickerFeatureLayers;

        // create container for Editor
        var editorContainer = domConstruct.create("div", {
          innerHTML: '<img style="display:inline;" src=""/>',
          "style": "text-align:center;"
        }, this.containerNode, "only");

        require(["esri/dijit/editing/Editor",
                "esri/dijit/editing/TemplatePicker",
                 "dojo/domReady!"], lang.hitch(this, function (Editor, TemplatePicker) {

          //if (templatePickerOptions != null) {
          //  console.log("new TemplatePicker => " + templatePickerOptions);
          //  this.templatePicker = new TemplatePicker(templatePickerOptions, templatePickerContainer);
          //  this.templatePicker.startup();
          //  ops.templatePicker = this.templatePicker;
          //}

          console.log("click on new Editor => " + ops);
          this.editor = new Editor({
            'settings': ops
          }, editorContainer);
          this.editor.startup();
        }));

        this.map.enableSnapping({
         tolerance: 20,
          snapKey: dojo.keys.ALT
        });

        this.toggleBTN.set('label', 'Stop Editing');
        this.isEdit = true;
      } else {
        this.editor.destroyRecursive();
        this.toggleBTN.set('label', 'Start Editing');
        this.isEdit = false;
        this.editor = null;
        this.templatePicker = null;
      }
    }
  });
});
4

0 に答える 0