Select2事件on(“ change”)会返回空数据参数

时间:2018-08-03 21:02:51

标签: javascript jquery jquery-select2

我正在尝试为summernote v0.8.9创建一个插件,并且正在使用select2库来创建下拉列表。

在我的代码下面找到:

(function(factory) {
  if (typeof define === 'function' && define.amd) {
    define(['jquery'], factory);
  } else if (typeof module === 'object' && module.exports) {
    module.exports = factory(require('jquery'));
  } else {
    factory(window.jQuery);
  }
}(function($) {

  $.extend($.summernote.plugins, {
    'insertData': function(context) {
      var self = this;

      var ui = $.summernote.ui;
      var $editor = context.layoutInfo.editor;
      var options = context.options;

      context.memo('button.insertData', function() {
        return ui.button({
          contents: '<i class="fa fa-database">',
          tooltip: 'Create InsertData',
          click: context.createInvokeHandler('insertData.showDialog')
        }).render();
      });

      self.initialize = function() {
        var $container = options.dialogsInBody ? $(document.body) : $editor;

        var body = '<div class="form-group">' +
          '<label>Select</label>' +
          '<select id="selectBox"></select>' +
          '</div>' +
          '<label>InsertData</label>' +
          '<input id="input-insertData" class="form-control" type="text" placeholder="Insert your insertData" />'
        var footer = '<button href="#" class="btn btn-primary ext-insertData-btn">OK</button>';

        self.$dialog = ui.dialog({
          title: 'Create InsertData',
          fade: options.dialogsFade,
          body: body,
          footer: footer
        }).render().appendTo($container);
        self.selectItem()
        self.fillSelectField();
      };

      self.destroy = function() {
        self.$dialog.remove();
        self.$dialog = null;
      };

      self.showDialog = function() {
        self
          .openDialog()
          .then(function(data) {
            ui.hideDialog(self.$dialog);
            context.invoke('editor.restoreRange');
            self.insertToEditor(data);
            console.log("dialog returned: ", data)
            // ...
          })
          .fail(function() {
            context.invoke('editor.restoreRange');
          });
      };

      self.openDialog = function() {
        return $.Deferred(function(deferred) {
          var $dialogBtn = self.$dialog.find('.ext-insertData-btn');
          var $elemInput = self.$dialog.find('#input-element')[0];
          var $insertDataInput = self.$dialog.find('#input-insertData')[0];

          var selectedText = $.selection()
          $('#input-element').val(selectedText);
          context.invoke('editor.saveRange');
          console.log("show dialog: " + selectedText)

          ui.onDialogShown(self.$dialog, function() {
            context.triggerEvent('dialog.shown');

            $dialogBtn
              .click(function(event) {
                event.preventDefault();

                deferred.resolve({
                  element: $elemInput.value,
                  insertData: $insertDataInput.value
                });
              });
          });

          ui.onDialogHidden(self.$dialog, function() {
            $dialogBtn.off('click');

            if (deferred.state() === 'pending') {
              deferred.reject();
            }
          });

          ui.showDialog(self.$dialog);
        });
      };

      this.selectItem = function() {
        $('#selectBox').on("change", function(e) {
          console.log("event")
          console.log(e)
          var data = e.params.data;
          console.log(data);

          $('#input-insertData').text("test")
        });
      }

      this.fillSelectField = function() {
        var data = []
        var text = $('.note-editable').html()
        data = text.match(/{{\s*\$\w+\s*}}/g)
        data.push("null"); // add empty value to array
        data = data.filter((v, i, a) => a.indexOf(v) === i); // only unique values

        $("#selectBox").select2({
          width: 'resolve',
          data: data
        })
      }
    }
  });
}));
<link href="https://stackpath.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-pdapHxIh7EYuwy6K7iE41uXVxGCXY0sAjBzaElYGJUrzwodck3Lx6IE2lA0rFREo" crossorigin="anonymous">
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.10/summernote.css" />
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/css/select2.min.css" rel="stylesheet" />

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/js/select2.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.10/summernote.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery.selection/1.0.1/jquery.selection.js"></script>

<div class="container">
  <div class="summernote">
    <p>Hello World!</p>
    {{ $slot }} {{$slot}} {{$category}} {{$s }} {{ $slot}}
  </div>
</div>

如您所见,当我按下按钮并选择一个元素时,我只会返回一个空事件e

enter image description here

在上面的示例中,我从下拉列表中进行选择,除了要从下降事件中返回函数this.selectItem的数据参数。我想在下一步中将这个值添加到我的输入字段中。

为什么事件e中的数据字段为空? 我在做什么错了?

1 个答案:

答案 0 :(得分:1)

您需要initial select2才能开始监听事件和存储数据。

$('#selectBox').select2();  //initialized
$('#selectBox').on("change", function(e) {
      console.log("event")
      console.log(e)
      var data = e.params.data;
      console.log(data);

      $('#input-insertData').text("test")
    });