簡體   English   中英

jQuery-chosen - 將所選選項的自定義選項屬性推送到列表

[英]jQuery-chosen - Push custom option attribute of selected option to list

我有一個如下所示的選項列表

<select data-placeholder="Choose users" style="width:350px;" multiple class="chosen-select" tabindex="8">
    <option data-user-id="1">User1</option>
    <option data-user-id="3">User2</option>
    <option data-user-id="6">User3</option>
    <option data-user-id="14">User4</option>
</select>

我可以使用selected plugin選擇多個選項。 每個選定的值都輸入到新的<li>元素中,如下所示:

<li class="search-choice"><span>User</span><a class="search-choice-close" data-option-array-index="2"></a></li>

有沒有辦法將 data-user-id 從選項推送到上面的<li>

我可以在不破解所選插件的情況下做到這一點嗎?

下面你會通過改變一點選擇的插件找到我的解決方案

SelectParser.prototype.add_option里面,我使用 jquery 獲得了我的自定義屬性,然后我將它作為一個選項推送。

SelectParser.prototype.add_option看起來像:

SelectParser.prototype.add_option = function(option, group_position, group_disabled) {
  if (option.nodeName.toUpperCase() === "OPTION") {
    if (option.text !== "") {
      if (group_position != null) {
        this.parsed[group_position].children += 1;
      }
      this.parsed.push({
        user_id: $(option).attr('data-user-id'),
        array_index: this.parsed.length,
        options_index: this.options_index,
        value: option.value,
        text: option.text,
        html: option.innerHTML,
        title: option.title ? option.title : void 0,
        selected: option.selected,
        disabled: group_disabled === true ? group_disabled : option.disabled,
        group_array_index: group_position,
        group_label: group_position != null ? this.parsed[group_position].label : null,
        classes: option.className,
        style: option.style.cssText
      });
    } else {
      this.parsed.push({
        array_index: this.parsed.length,
        options_index: this.options_index,
        empty: true
      });
    }
    return this.options_index += 1;
  }
};

正如你注意到的,我只放了這個user_id: $(option).attr('data-user-id'),代碼行。

然后將 data-user-id 推送到<li>列表,我將這一行'data-user-id': item.user_idChosen.prototype.choice_build所以最后它看起來像:

  Chosen.prototype.choice_build = function(item) {
      var choice, close_link,
        _this = this;
      choice = $('<li />', {
        "class": "search-choice"
      }).html("<span>" + (this.choice_label(item)) + "</span>");
      if (item.disabled) {
        choice.addClass('search-choice-disabled');
      } else {
        close_link = $('<a />', {
          "class": 'search-choice-close',
          'data-option-array-index': item.array_index,
          'data-user-id': item.user_id
        });
        close_link.bind('click.chosen', function(evt) {
          return _this.choice_destroy_link_click(evt);
        });
        choice.append(close_link);
      }
      return this.search_container.before(choice);
    };

就是這樣! 您可以通過這種方式推送任意數量的自定義屬性。

我已經用 selected_v1.8.7 對此進行了測試。 正如@panagiotis-koursaris 在他的回答中指出的那樣,可以將行user_id: $(option).attr('data-user-id')到第一個函數中:

SelectParser.prototype.add_option = function(option, group_position, group_disabled) { 
if (option.nodeName.toUpperCase() === "OPTION") { 
    if (option.text !== "") { 
      if (group_position != null) { 
        this.parsed[group_position].children += 1; 
      } 
      this.parsed.push({ 
        user_id: $(option).attr('data-user-id'), 
        array_index: this.parsed.length, 
        options_index: this.options_index, 
        value: option.value, 
        text: option.text, 
        html: option.innerHTML, 
        title: option.title ? option.title : void 0, 
        selected: option.selected, 
        disabled: group_disabled === true ? group_disabled : option.disabled, 
        group_array_index: group_position, 
        group_label: group_position != null ? this.parsed[group_position].label : null, 
        classes: option.className, 
        style: option.style.cssText 
      }); 
    } else { 
      this.parsed.push({ 
        array_index: this.parsed.length, 
        options_index: this.options_index, 
        empty: true 
      }); 
    } 
    return this.options_index += 1; 
  } 
};

但您還需要添加這一行option_el.setAttribute("data-user-id", option.user_id); 到 AbstractChosen.prototype.result_add_option:

AbstractChosen.prototype.result_add_option = function(option) {
      var classes, option_el;
      if (!option.search_match) {
        return '';
      }
      if (!this.include_option_in_results(option)) {
        return '';
      }
      classes = [];
      if (!option.disabled && !(option.selected && this.is_multiple)) {
        classes.push("active-result");
      }
      if (option.disabled && !(option.selected && this.is_multiple)) {
        classes.push("disabled-result");
      }
      if (option.selected) {
        classes.push("result-selected");
      }
      if (option.group_array_index != null) {
        classes.push("group-option");
      }
      if (option.classes !== "") {
        classes.push(option.classes);
      }
      option_el = document.createElement("li");
      option_el.className = classes.join(" ");
      if (option.style) {
        option_el.style.cssText = option.style;
      }
      option_el.setAttribute("data-option-array-index", option.array_index);
      // Add the line below
      option_el.setAttribute("data-user-id", option.user_id);
      option_el.innerHTML = option.highlighted_html || option.html;
      if (option.title) {
        option_el.title = option.title;
      }
      return this.outerHTML(option_el);
    };

我建議使用 value 屬性而不是 data 屬性。

<select data-placeholder="Choose users" style="width:350px;" multiple class="chosen-select" tabindex="8">
    <option value="1">User1</option>
    <option value="3">User2</option>
    <option value="6">User3</option>
    <option value="14">User4</option>
</select>

然后你可以使用

$('select').val(); //use a name or id attribute to make this selector more specific..

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM